1. 为了演示方便,首先新建一个控制台项目,然后添加对entityframework的引用

使用nuget控制台执行: Install-Package EntityFramework

2.新建一个实体“Student”,数据访问类“StudentsContext”,代码如下:

public class Student
{
public int Id { get; set; }
public string Name { get; set; }
}
public class StudentsContext:DbContext
{
public DbSet<Student> Students { get; set; } }

3.启用数据迁移。

3.1 打开nuget控制台,执行如下命令:

Enable-Migrations

执行此命令之后,项目中会自动添加一个文件夹“Migrations”,并且会自动生成一个数据迁移配置文件“Configuration.cs”。如果此时之前已经访问过“StudentsContext”,还会在此文件夹下生成一个初始化的迁移文件“xxxxx_InitialCreate.cs”,xxxx是执行命令时的日期序号。(当然我这里还没有访问过“StudentsContext”,所以没有生成该文件)如下图:

3.2 添加数据迁移。

打开nuget控制台,执行如下命令(如果在此之前,数据库已经生成并使用过了,那么此命令会在启用迁移的时候默认执行过了,所以不必再执行。见3.1文字信息):

Add-Migration InitialCreate

执行此命令后,会在“Migrations”文件夹下生成一个初始化的迁移文件“xxxxx_InitialCreate.cs”。每个迁移文件都包含Up和Down两个重写函数,分别对应于更新和回退。上面的代码也很直白,Up函数中创建一个Students表并定义了表结构,Down函数用来回退操作,里面简单的删除了Students表。如下:

 using System.Data.Entity.Migrations;

     public partial class InitialCreate : DbMigration
{
public override void Up()
{
CreateTable(
"dbo.Students",
c => new
{
Id = c.Int(nullable: false, identity: true),
Name = c.String(),
})
.PrimaryKey(t => t.Id); } public override void Down()
{
DropTable("dbo.Students");
}
}

3.3 添加数据迁移。

3.3.1 修改“Student”类,改成如下结构:

public class Student
{
public int Id { get; set; }
[MaxLength()]
public string Name { get; set; }
public int Age { get; set; }
}

3.3.2 然后在nuget命令控制台执行如下代码,添加一个数据迁移项:

Add-Migration Add_Student_Name_Age

执行命令后,会在“Migrations”文件夹下生成一个名为“xxxx_Add_Student_Name_Age.cs”的数据迁移文件,文件的内容就是刚才对实体更改的记录。如下:

public partial class Add_Student_Name_Age : DbMigration
{
public override void Up()
{
AddColumn("dbo.Students", "Age", c => c.Int(nullable: false));
AlterColumn("dbo.Students", "Name", c => c.String(maxLength: ));
} public override void Down()
{
AlterColumn("dbo.Students", "Name", c => c.String());
DropColumn("dbo.Students", "Age");
}
}

3.3.3 执行迁移计划。打开nuget控制台,执行如下命令:

update-database

到此,第一次数据迁移已经完成了,打开数据表“Students”就回发现,刚才做的更改已经执行并生效了。

3.4 生成数据迁移脚本文件

在真实环境中数据库可能是部署在远程服务器的,所以可以生成数据迁移脚本文件,然后去远程服务器执行。在nuget控制台执行如下命令:

Update-Database -Script -SourceMigration: InitialCreate -TargetMigration: Add_Student_Name_Age

执行命令后,会得到一个脚本文件,如下:

ALTER TABLE [dbo].[Students] ADD [Age] [int] NOT NULL DEFAULT 0
ALTER TABLE [dbo].[Students] ALTER COLUMN [Name] [nvarchar](20) NULL
INSERT [dbo].[__MigrationHistory]([MigrationId], [ContextKey], [Model], [ProductVersion])
VALUES (N'201612300600368_Add_Student_Name_Age', N'EfCodeFirstMigrations.Migrations.Configuration', 0x1F8B0800000000000400CD57DB6EDB38107D5F60FF81E0736AC6CE4B37905B649D6411B44E822AED3B2D8D146229522B5281FD6DFBB09FD45FE8507753BE25288A450023A666CE9C399A0BFDFDDFFF828FEB4C9217288CD06A4EA793734A40453A162A9DD3D226EFDED38F1F7EFF2DB889B335F9D6DA5D383BF454664E9FADCD2F1933D13364DC4C321115DAE8C44E229D311E6B363B3FFF834DA70C1082221621C19752599141F505BF2EB48A20B725974B1D8334CD393E092B5472CF3330398F604E6F9205DADC8AC2D8A5480B6E919099D47E945C49C191530832A1842BA56D6570F9D540680BADD230C7032E9F3639A05DC2A5812693CBDEFCD4A4CE672E29D63BB6505169ACCE5E0938BD685462BEFB9BB4A69D8AA8E30DEA6D372EEB4A4B54C89631284B891FEB72210B677758E949E37F46765A9D75A58215E5FECEC8A294B62C60AEA0B4059767E4B15C49117D82CD93FE1BD45C95520E2923697CB67580478F85CEA1B09B2F903489DCC594B06D3FE63B766E039F3AC73B652F6694DC6370BE92D055C4408FD0EA02FE0205981BC48FDC5A2894C3804AD351742F96FB6CA36109625F51B2E4EBCFA052FB3CA7336CA45BB186B83D68087C5502BB107D6C51C2B11857291C4B680810B0BE1CC64582CD68B9C074B72BC5B87358EFAA186CAEA6684CC3779B6D8D1B82F51029E979D43D3BE9CA7217DF8E593F1F583D20DA41C2F64C9260C9F31CA51F4C96E68484F55859BC0B5FDF65598DC122B3A3D93AB65D242C249E82F71443B7FD73CD2D5F71F7B616713632F3DFC31E8DDB689ED47E23F5CAB70EEEFFDAE994C6F7017B456F31C90C2DAA7CA1E3D58F9C916735E7B9E4C58E365D6859666A5FAB1FF2AE1B6FE85F9F9C8E50B5D510A03A18FB07CC4BDD179B8DD4F60696FFF60E15BF6FD245EF9AC02BF6A029BCE3BB755489B5092528CC8B88AB2ADC180BD9C4194CC27FE4428AAA5D5B832557220163EB998ED36D3AF396F2FF674132636279DA96FCE57B4938518F6E9E8353FEF02A522FBC889E79315A463DE62B374F45F927EE9DF1583C69AB1C5A2A7539CF69BCD2C8BAE6D92FA337AE9C7177056C78BF0DAEC188B48770B75D05912BDB1EB4B5B953896E25C6D4868C5A13EF0D2CC1F21815BA2AAC487864F17104C654F78C6F5C966E9E672B88EFD44369F3D25E1903D94A6EDD5B0276387EB557B739070F79B5167E460A4853600AF0A0FE2C858C3BDEB73B4A680F842B96A6539015DEB3102EDD7448F75A9D08D4C8770D392857174F90E512C1CC830AF90BBC851B5E8F3E43CAA34D3B24F7831C7F11DBB207D782E382CE4C83D1FBBBDF6CCCFD68FBF003592E236AE60D0000 , N'6.1.3-40302')

有了这个脚本文件,就可以很方便的执行数据迁移了。

Entity Framework Code First Migrations--EF 的数据迁移的更多相关文章

  1. Entity Framework Code First -- Migrations 迁移

    在开始使用迁移(Migrations)之前,我们需要一个 Project 和一个 Code First Model, 对于本文将使用典型的 Blog 和 Post 模型 创建一个新的控制台应用程序 M ...

  2. Entity Framework Code First 数据迁移

    需要在[工具 --> NuGet 程序包管理器 --> 程序包管理器控制台]中输入三个命令: Enable-Migrations (初次迁移时使用) Add-Migration [为本次迁 ...

  3. How to: Use the Entity Framework Code First in XAF 如何:在 XAF 中使用EF CodeFirst

    This topic demonstrates how to create a simple XAF application with a business model in a DbContext ...

  4. Entity Framework Code first(转载)

    一.Entity Framework Code first(代码优先)使用过程 1.1Entity Framework 代码优先简介 不得不提Entity Framework Code First这个 ...

  5. Entity Framework Code First学习系列目录

    Entity Framework Code First学习系列说明:开发环境为Visual Studio 2010 + Entity Framework 5.0+MS SQL Server 2012, ...

  6. Entity Framework Code First学习系列

    Entity Framework Code First学习系列目录 Entity Framework Code First学习系列说明:开发环境为Visual Studio 2010 + Entity ...

  7. 使用 Entity Framework Code First

    使用 Entity Framework Code First 在家闲着也是闲着,继续写我的[ASP.NET MVC 小牛之路]系列吧.在该系列的上一篇博文中,在显示书本信息列表的时候,我们是在程序代码 ...

  8. Entity Framework Code First 迁移

    Entity Framework CodeFirst数据迁移 http://www.cnblogs.com/aehyok/p/3325459.html Entity Framework Code Fi ...

  9. Entity Framework与ADO.NET批量插入数据性能测试

    Entity Framework是.NET平台下的一种简单易用的ORM框架,它既便于Domain Model和持久层的OO设计,也提高了代码的可维护性.但在使用中发现,有几类业务场景是EF不太擅长的, ...

  10. Entity Framework Code First数据库连接

    1. 安装Entity Framework 使用NuGet安装Entity Framework程序包:工具->库程序包管理器->程序包管理器控制台,执行以下语句: PM> Insta ...

随机推荐

  1. 著名ERP厂商的SSO单点登录解决方案介绍一

          SSO英文全称Single Sign On,单点登录.SSO是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统.它包括可以将这次主要的登录映射到其他应用中用于同一个用户 ...

  2. Express 教程 01 - 入门教程之经典的Hello World

    目录: 前言 一.Express?纳尼?! 二.开始前的准备工作 三.测试安装之经典的Hello World 四.使用express(1)来生成一个应用程序 五.说明 前言: 本篇文章是建立在Node ...

  3. [AlwaysOn Availability Groups]健康模型 Part 1——概述

    健康模型概述 在成功部署AG之后,跟踪和维护健康状况是很重要的. 1.AG健康模型概述 AG的健康模型是基于策略管理(Policy Based Management PBM)的.如果不熟悉这个特性,可 ...

  4. Linux命令

    系统信息 arch 显示机器的处理器架构(1) uname -m 显示机器的处理器架构(2) uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 - (SMBIOS ...

  5. Linux CentOS7通过yum命令安装Mono(尝先安装模式)

    前言 经过尝试网上各种安装mono的技术贴,这个安装过程经历了大约2周,尝试了各个版本,几目前博客所描述的所有安装方式.以下内容的安装方式可以为你尝试不同版本的mono.并非正式环境安装标准方式安装. ...

  6. CentOS7下自定义目录安装mono+jexus教程

    一.阅读前须知: 1.本文属于安装完Centos7之后的步骤 2.如果还不了解mono,请点击mono 3.本篇主要内容是使用自定义目录安装mono+jexus教程,使用默认目录请查看使用默认目录安装 ...

  7. JDK 中的证书生成和管理工具 keytool

    参考资料 该文中的内容来源于 Oracle 的官方文档 Java SE Tools Reference .Oracle 在 Java 方面的文档是非常完善的.对 Java 8 感兴趣的朋友,可以直接找 ...

  8. CSharpGL(12)用T4模板生成CSSL及其renderer代码

    CSharpGL(12)用T4模板生成CSSL及其renderer代码 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码中包含10多个独立 ...

  9. 正确地编写Objective-C中的便捷方法

    在Objective-C中,如果某个类方法的返回类型就是这个类的实例(例如NSString类中的stringWithFormat:),就可以将这种类方法称为便捷方法(Convenience Metho ...

  10. Entity Framework 6 Recipes 2nd Edition(11-2)译 -> 用”模型定义”函数过滤实体集

    11-2. 用”模型定义”函数过滤实体集 问题 想要创建一个”模型定义”函数来过滤一个实体集 解决方案 假设我们已有一个客户(Customer)和票据Invoice)模型,如Figure 11-2所示 ...