新版EF,系统实现过程中如果对Model进行更改,队形修改数据库并不能正常运行项目,需要借助Code First 手动迁移数据库

首先启用迁移,允许迁移Context

Tools->Library Package Manager->Package Manager Console 运行 Enable-Migrations

执行命令在项目中创建Migrations 文件夹 ,包含两个类

Configuration 类:给定迁移的相关配置

InitialCreate 类:继承迁移基类,实现Up和Down方法,Up方法数据库向上迁移时执行,Down方法数据库向下迁移时执行。主要是实现数据库的建表,删除表,添加列,删除列,创建主键、外键,删除主键、外键,重命名等操作。

接下来就可以生成迁移和执行迁移

Add-Migration + 迁移名  将根据自创建上次迁移以来您对模型所做的更改,为下一次迁移搭建基架。

  该操作生成一个迁移名定义的类,和InitialCreate 类一样,定义了相应的数据库更改操作。

Update-Database 将所有挂起的迁移应用于数据库。

  迁移到特定版本(包括降级)  运行 Update-Database –TargetMigration: 迁移名

  如果要一直回滚到空数据库,可以使用 Update-Database –TargetMigration: $InitialDatabase 

如何实现数据的移动和更改(如新创建的列,采用已存在列的数据填充):

  Sql("相应的SQL数据操作语句");

获取 数据库迁移 SQL 脚本(如将更改推送到测试服务器或其他开发人员机器)

  运行 Update-Database 命令,但此时指定 –Script 标记,使更改写入脚本而不应用。

  希望产生的脚本是从一个空数据库($InitialDatabase)到最新的版本 (-TargetMigration为空即可

    Update-Database -Script -SourceMigration: $InitialDatabase  -TargetMigration:

应用程序启动时自动升级

  通过注册 MigrateDatabaseToLatestVersion 数据库初始化器来实现这一点,数据库初始化器只包含一些逻辑检查用于确保数据库被正确设置,这个逻辑检查将会在context 第一次被使用的时候执行。

  启动时通过 Database.SetInitializer(new MigrateDatabaseToLatestVersion<XXContext,Configuration>()); 设定MigrateDatabaseToLatestVersion 初始值设定项

Entity Framework Code First 迁移数据库的更多相关文章

  1. Entity Framework Code First 迁移

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

  2. Entity Framework Code First 多数据库 控制台迁移代码

    1.启动迁移 Enable Migrations Enable-Migrations -MigrationsDirectory "MigrationsOne" -ContextTy ...

  3. ASP.NET MVC+Entity Framework code first 迁移

    再来一张,选择 MVC 模版,其他的没选过,不会用 =_=!! 身份验证用个人用户账户,这个是为了偷懒,话说 ASP.NET Identity  还是很给力的,不用白不用 ^_^~ 点击确定之后,会看 ...

  4. Entity Framework Code First迁移基本面拾遗

    项目中用到了EF Code First和迁移,但发现有些方面似懂非懂.比如:如何在迁移文件中控制迁移过程?如果在迁移文件中执行SQL语句?如何使用Update-Database的其它参数?数据库在生产 ...

  5. Entity FrameWork Code First 迁移命令详解

    1. Enable-Migrations 启动迁移 执行get-help Enable-Migrations –detailed 查看Enable-Migrations的详细用法. -ContextT ...

  6. Entity Framework Code First数据库连接

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

  7. Entity Framework Code First属性映射约定

    Entity Framework Code First与数据表之间的映射方式有两种实现:Data Annotation和Fluent API.本文中采用创建Product类为例来说明tity Fram ...

  8. Entity Framework Code First关系映射约定

    本篇随笔目录: 1.外键列名默认约定 2.一对多关系 3.一对一关系 4.多对多关系 5.一对多自反关系 6.多对多自反关系 在关系数据库中,不同表之间往往不是全部都单独存在,而是相互存在关联的.两个 ...

  9. Entity Framework Code First主外键关系映射约定

    本篇随笔目录: 1.外键列名默认约定 2.一对多关系 3.一对一关系 4.多对多关系 5.一对多自反关系 6.多对多自反关系 在关系数据库中,不同表之间往往不是全部都单独存在,而是相互存在关联的.两个 ...

随机推荐

  1. PhoneTutorial

    https://github.com/navasmdc/PhoneTutorial PhoneTutorial-master.zip

  2. PHP获取用户真实 IP , 淘宝IP接口获得ip地理位置(转)

    <?php /** * 获取用户真实 IP */ function getIP() { static $realip; if (isset($_SERVER)){ if (isset($_SER ...

  3. /proc/sys/net/ipv4/下各项的意义

        /proc/sys/net/ipv4/icmp_timeexceed_rate这个在traceroute时导致著名的“Solaris middle star”.这个文件控制发送ICMP Tim ...

  4. perl详解

    http://www.blogjava.net/qileilove/archive/2013/09/04/403646.html

  5. UIDatePicker的时间选择器里的时区的问题

    转自:http://www.cocoachina.com/bbs/simple/?t70445.html 初始化代码: - (void)viewDidLoad { [super viewDidLoad ...

  6. php运行步骤解析

    2000年, PHP4.0发布的时候,引入了Zend Engine. Zend引擎把PHP代码的执行切分成两个阶段: 一. Zend Engine 解析PHP代码并生成二进制中间码Zend Opcod ...

  7. 12096 - The SetStack Computer UVA

    Background from Wikipedia: \Set theory is a branch of mathematics created principally by the German ...

  8. css笔记07:通配符选择器

    通配符选择器: * { margin:10px ;//默认四个位置参数全为零 margin-top:10px;//分别设置四个参数 margin-left:10px; margin-right:0px ...

  9. Android(java)学习笔记103:Map集合的获取功能

    package cn.itcast_01; import java.util.Collection; import java.util.HashMap; import java.util.Map; i ...

  10. 在SSIS 的 64 位版本中不支持 Excel 连接管理器

    Microsoft sql server 2008 R2——> SQL SERVER Business Intelligence Development Studio 使用EXCEL数据源或目标 ...