EntityFramework CodeFirst 数据库迁移

参考:

https://msdn.microsoft.com/en-us/data/jj591621

http://www.itnose.net/detail/6105449.html

http://www.tuicool.com/articles/Q7JRR32

打开:工具 --> NuGet包管理器 --> 程序包管理控制台,按下面的步骤使用相应的命令

//使能迁移功能

命令1. Enable-Migrations -ContextTypeName WebTest.Models.TestDbContext -MigrationsDirectory MigrationsTestDbContext

(Enable-Migrations -ContextTypeName 数据库上下文名称(使用完全限定名,即包含名称空间) -MigrationsDirectory 文件夹名称)

(此命令支持包含多个数据库上下文的项目,将为每个数据库上下文创建独立的文件夹)

//添加迁移数据快照

命令2. Add-Migration -configuration WebTest.MigrationsTestDbContext.Configuration InitialCreate

(Add-Migration -configuration 要使用的配置名称(使用完全限定名) 自定义的快照名称(自动添加一个时间戳前缀))

(模型类发生改变后,使用此命令添加迁移快照,其中第一次使用时(未创建数据库时)一般使用“InitialCreate”命名)

//更新数据库,将迁移快照应用于数据库

命令3. Update-Database -configuration WebTest.MigrationsTestDbContext.Configuration -Verbose

(Update-Database -configuration 要使用的配置名称(使用完全限定名) -Verbose(可选,显示详细信息,生成的sql语句))

//回退数据库

命令4. Update-Database -ProjectName:WebTest -TargetMigration:"201706291258382_InitialCreate" -verbose

一般步骤:

1.   设置连接字符串,创建模型类

2.   编译项目

3.   使用命令1开启迁移功能

4.   编译项目

5.   使用命令2添加初始化快照

6.   编译项目

7.   使用命令3,将自动创建数据库,至此数据库初始化完成

8.   当业务调整,数据库需要修改时,修改模型类

9.   编译项目

10. 使用命令2添加迁移快照(最好使用有意义的名称,比如"AddTestBsTable")

11. 编译项目

12. 使用命令3更新数据库,将在保留原数据的情况下升级数据库架构,使数据库架构与最新的模型保持一致

//其它

//获取帮助
get-help Enable-Migrations
//获取示例
get-help Enable-Migrations -examples
//获取帮助
get-help Add-Migration -full

//如果出现 Apply the pending explicit migrations before attempting to generate a new explicit migration. 错误,表示有挂起的迁移操作未执行,此时可以先将上一次的快照(如:"201706291123246_InitialCreate.cs")中的 Up() 方法内的代码全部注释掉,再运行一次update-database,就是什么也不做,单纯执行完挂起的migration。

//对已经发布在服务器上的网站应用数据库迁移

如下图所示,在web发布选项中勾选 Execute Code First Migrations (runs on application start)

时间: 2024-10-09 18:38:06

EntityFramework CodeFirst 数据库迁移的相关文章

EF codefirst 数据库迁移

如果出现 未能加载文件或程序集“Microsoft.VisualStudio.Shell, Version=10.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a”或它的某一个依赖项.系统找不到指定的文件. 重新安装EF 命令Install-Package EntityFramework 在此之后 主要是3步走: 1:Enable-Migrations -ContextTypeName MvcMovie.Models.MovieDbC

基于 ASP.NET Core 2.0 WebAPI 后台框架搭建(2) - EF Core (MySQL) CodeFirst 数据库迁移与依赖注入

概述 上一章,我们简单的搭建了依赖注入的三层架构,但是,没有真正的使用,而我们现在就使用MySQL数据,基于 EF Core 的 DbFirst 进行框架搭建. 微软爸爸官方文档:使用新数据库在 ASP.NET Core 上开始使用 EF Core    数据库表字段命名规范 步骤 1. 右击 Entity 项目,点击"管理NuGet程序包" 2. 安装以下三个包 Microsoft.EntityFrameworkCore     安装版本:2.1.0 Microsoft.Entity

CodeFirst数据库迁移小记

打开“程序包管理器控制台”菜单项一.Enable-Migrations -ContextTypeName Code_First_数据迁移.Models.T_DbContext成功后提示:已在项目“Code First 数据迁移”中启用迁移.若要覆盖现有迁移配置,请使用 -Force 参数.        且在项目中新建了Migrations文件夹和Configuration文件 二.修改Configuration文件中Seed方法,并重新编译解决方案protected override void

codefirst数据库迁移

一.为模型更改设置 Code First 数据迁移 1.工具->库程序包管理器->程序包管理器控制台->输入"Enable-Migrations"  或者 Enable-Migrations -ContextTypeName Mvc.Models.DataContext Enable-Migrations -ContextTypeName 命名空间.上下文名称 注:如果正确的话 则显示"已为项目 xxx启用 Code First 迁移.", Ena

Entityframework codefirst 数据库变更

数据模型变更  变更数据库 nuget 控制台 输入Enable-Migrations(中间没有空格)   在Migrations文件夹下  会生成当前数据库的信息 输入Add-Migration  filename (自己命名)   在Migrations文件夹下  会生成当前模型变更信息  (自动检索当前项目 继承自EntityTypeConfiguration 的map) 输入update-database 把变化应用到数据库

基于 ASP.NET Core 2.0 WebAPI 后台框架搭建(4) - EF Core CodeFirst 数据库创建

概述 在 基于 ASP.NET Core 2.0 WebAPI 后台框架搭建(2) - EF Core (MySQL) CodeFirst 数据库迁移与依赖注入 一文中,我们介绍如何快速以CodeFirst快速搭建数据库,这一章,我们来完善一下创建数据库中可以添加的验证与约束. 微软爸爸官方文档:Entity Framework Core 数据库操作 (1) 数据库迁移  add-migration [任一名称,须唯一] (2) 更新数据库  update-database (3) 删除数据库迁

EF CodeFirst 数据库创建与迁移

一.EF CodeFirst 根据实体创建数据库 1.新建好实体类 2.添加数据库上下文的类StudentInfoEntities:继承DbContext 3.配置Web.Config连接数据库字符串(name=“数据库上下文类的名称”) 4.写个controller运行代码,自动生成数据库 二.迁移数据库(sqlserver) 当修改实体属性后需要迁移数据库:打开工具-->NuGet程序包管理器-->程序包管理器控制台 1.第一次迁移先执行命令:Enable-Migrations 2.Add

20.翻译系列:Code-First中的数据库迁移技术【EF 6 Code-First系列】

原文链接:https://www.entityframeworktutorial.net/code-first/migration-in-code-first.aspx Entity Framework Code-First有很多不同的数据库初始化策略,例如:CreateDatabaseIfNotExists[创建数据库,如果不存在的话].DropCreateDatabaseIfModelChanges[如果模型发生改变的话,就删除重建数据库].DropCreateDatabaseAlways[

20.2.翻译系列:EF 6中基于代码的数据库迁移技术【EF 6 Code-First系列】

原文链接:https://www.entityframeworktutorial.net/code-first/code-based-migration-in-code-first.aspx 在前面的一节中,你学习了自动迁移技术,当实体改变的时候,自动进行数据库迁移.这里你将会学习基于代码的数据库迁移技术. 基于代码的数据库迁移技术,在迁移的时候,提供了更多的控制.例如允许你配置添加额外的字符串,例如设置列的默认值,配置计算列等等. 为了使用基于代码的数据库迁移,你需要在程序包管理控制台中输入: