EntityFramework - Code First - 数据迁移
需求
在更新模型之后同步更新数据库里的表,并不丢失原有数据
使用默认值填充新增加的字段
EntityFramework迁移命令
Enable-Migrations 启用迁移
Add-Migration 为挂起的Model变化添加迁移脚本
Update-Database 将挂起的迁移更新到数据库
Get-Migrations 获取已经应用的迁移
DEMO
Model中的原类型
class Student
{
public int ID { get; set; }
public int Name { get; set; }
}
更新后
class Student
{
public int ID { get; set; }
public int Name { get; set; }
public int Age{get;set;}
}
在程序控制台中输入:
PM> Enable-Migrations
// 启用迁移
// 参数:
// -ContextTypeName:项目继承自DBContext的类名字。
// -EnableAutomaticMigrations:开启自动迁移。
// -ProjectName:存放DBContext类的项目名称。
// -StartUpProjectName:解决方案中启动项目的名称,作用是调用该项目下的连接字符串。
// -ConnectionStringName:连接字符串名称
// -ConnectionString: 指定使用的连接字符串
// -ConnectionProviderName: 指定连接字符串的provider名称
// -Force:重写迁移配置 结果:
检测到数据库是由database initializer创建,为现有的数据库搭建初始化迁移脚本
1.在本项目下创建了Migrations文件夹
2.Migrations文件夹下创建Configuration类文件
Configuration类: 此类允许针对上下文配置迁移的行为
3.Migrations文件夹下创建_InitialCreate类文件(若为未生成数据库则无此文件)
InitialCreate类: 此类表示数据库已经创建的对象 可能会出现的错误
1. No context type was found in the assembly 'DEMO'
含义:找不到项目中的继承自DBContext的上下文类
原因:
1.没有上下文类
2.指定了错误的项目
解决方案:
1.添加一个继承自DBContext的上下文类
PM> Add-Migration
// 为挂起的Model变化添加迁移脚本
// 参数:// -Name: 指定脚本名称
// -ProjectName:存放DBContext类的项目名称
// -StartUpProjectName:解决方案中启动项目的名称,作用是调用该项目下的连接字符串。
// -ConfigurationTypeName: 指定使用的迁移配置
// -ConnectionStringName:连接字符串名称
// -ConnectionString: 指定使用的连接字符串
// -ConnectionProviderName: 指定连接字符串的provider名称
// -Force:重写迁移配置
// -IgnoreChanges: 忽略检测挂起的model改变,创建一个空迁移 结果:
1.生成一个自称自DbMigration的类,包含Up()和Down()方法,代表了更新前后两个版本的改动细节
字段的增加 AddColumn()
字段的删除 DropColumn()
可能会出现的错误
PM> Update-Database // 将挂起的迁移更新到数据库
// 参数:
// -SourceMigration: 指定迁移的名称作用更新的起点,默认使用最后一次应用的迁移
// -TargetMigration: 指定将数据库更新到哪个迁移名称
// -Script:生成SQL脚本
// -Force: 重写迁移配置
// -ProjectName:存放DBContext的项目名称
// -StartProjectName: 解决方案中的启动项目名称
// -ConfigurationTypeName: 使用指定的配置
// -ConnectionStringName: 使用指定的连接字符串名称
// -ConnectionString: 使用指定的连接字符串
// -ConnectionProviderName: 指定连接字符串的provider名称 可能会出现的错误
找不到对象“dbo.Quarter”,因为它不存在或者您没有所需的权限。
应用程序启动后自动升级
使用 Enable-Migrations - EnableAutomaticMigrations 打开自动迁移
或者更改迁移配置脚本 Configuration 类构造函数
public Configuration()
{
// 开启自动更新
AutomaticMigrationsEnabled = true;
// 允许在自动更新时丢失数据
AutomaticMigrationDataLossAllowed = true;
}
在上下文类DBContext类中的构造函数
public DEMOContext() : base("name=DEMOContext")
{
Database.SetInitializer(new MigrateDatabaseToLatestVersion<DEMOContext, Configuration>());
}
EntityFramework - Code First - 数据迁移的更多相关文章
- 图文详解 解决 MVC4 Code First 数据迁移
在使用Code first生成数据库后 当数据库发生更改时 运行程序就会出现数据已更改的问题 这时可以删除数据库重新生成解决 但是之前的数据就无法保留 为了保留之前的数据库数据 我们需要使用到C ...
- 解决 MVC4 Code First 数据迁移 数据库发生更改导致调试失败解决方法(二)
文章转载自:http://www.cnblogs.com/amoniyibeizi/p/4486617.html 前几天学MVC过程中,遇到更改Model类以后,运行程序就会出现数据已更改的问题导致调 ...
- EF Code First 数据迁移配置
这里我想讲清楚code first 数据迁移的两种模式,还有开发环境和生产环境数据迁移的最佳实践. 1.1 数据迁移综述 EF Code first 虽然已经有了几种不同的数据库初始化策略,但是大部分 ...
- Code First 数据迁移 转
一.为模型更改设置 Code First 数据迁移 1.工具—>库程序包管理器—>程序包管理器控制台—>输入“Enable-Migrations” 或者 Enable-Migrat ...
- C#+EntityFramework编程方式详细之Code First 数据迁移
在前几篇的C#+EntityFramework编程方式中介绍了C#+EntityFramework编程方式Code First ,Model First以及Dtatabase First 等编程方式, ...
- Code first 数据迁移
前段时间用到了EF,整理一下 EF ,全称Entity FramWork.就是微软以ADO.NET为基础发展的所谓ORM(对象关系映射框架,或者说是数据持久化框架). 简单说就是根据实体对象操作数据库 ...
- EF Code First 数据迁移操作
打开执行命令窗体 1.EF Code First创建数据库 PM> Install-Package EntityFramework 2.EF Code First数据库迁移 2.1.生成数据库 ...
- EF6:编写你自己的code first 数据迁移操作(睡前来一篇,翻译的)
原英文版由EF团队成员 Rowan Miller 在2013年发表,此处只作翻译备忘. 数据迁移提供了一套强类型API,用于执行通用的操作,比如CreateIndex("dbo.Blogs& ...
- EF code First数据迁移学习笔记(转)
转自:http://www.cnblogs.com/icyJ/p/migration.html 准备工作 1.新建一个控制台项目, 在"程序包管理控制台"执行 Install-pa ...
随机推荐
- ubuntu下eclipse安装maven插件
ubuntu科输入如下指令安装eclipse:sudo apt-get install eclipse ubuntu下安装maven插件打开Eclipse点击Help -> Install Ne ...
- RK3288 HDMI配置和调试
RK3288 最大输出分辨率为 3840x2160 HDMI 驱动代码位于 kernel/drivers/video/rockchip/hdmi/rockchip-hdmiv2 目录 1.设置默认输出 ...
- 【转】JMeter测试有无数据库连接池的性能
使用JMeter测试一下有无数据库连接池的性能: 1.下载JMeter 2.无连接池的servlet Java代码 public void doGet(HttpServletRequest reque ...
- Maven构建项目速度太慢的解决办法 Maven 调试
Apache Maven是当今非常流行的项目构建和管理工具,它把开发人员从繁杂的项目依赖关系处理事务中解放出来,完全自动化管理依赖问题.在Web应用开发过程中,通常我们会用到maven的archety ...
- Nmon、nmon analyse安装及使用
性能监控算是性能测试中的一部分,测试人员需要去分析各类系统指标,CPU.网络.内存.磁盘I/O等等.嗯.通常linux系统下有诸如top.netstat.iostat等命令进行查看:而有时需要看某数据 ...
- C++:const_cast类型转换
针对const_cast,太多人在用同一个示例问同一个问题:void main(){ const int a = 3; const int *pc = &a; int *p = c ...
- 重载(overload),覆盖(override),隐藏(hide)的区别
写正题之前,先给出几个关键字的中英文对照,重载(overload),覆盖(override),隐藏(hide).在早期的C++书籍中,可能翻译的人不熟悉专业用语(也不能怪他们,他们不是搞计算机编程的, ...
- SQL Server Management Studio (SSMS)
最新的SQLServer数据库已经不集成SQL Server Management Studio需要单独下载安装. https://docs.microsoft.com/zh-cn/sql/ssms/ ...
- iframe callback方式文件上传
1.前端default.html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...
- svn关键词BASE, HEAD, COMMITTED, PREV的深入理解
svn关键词BASE, HEAD, COMMITTED, PREV可以很方便用于日常操作中,但是很多人对他们的工作原理和方式不是太了解. 在这里我将使用用例,诠释他们的作用和意图. 先给出svn手册中 ...