【Entity Framework】disable automatic migration, 执行update-migration仍然会显示有automatic migration
本文涉及的相关问题,如果你的问题或需求有与下面所述相似之处,请阅读本文
[Entity Framework] disable automatic migration, 执行update-migration仍然会显示有automatic migration
[Entity Framework] code base migration / automatic migration
问题起因
今天在做项目的时候需要修改db的两个column,将两个column的type改为nullable.
public int? AUsage { get; set; }
public int? BUsage { get; set; }
Package Manager Console中输入命令
Add-Migration xxxx
结果发现报错,提示有部分pending migration
.这个好解决,其实只要将那部分pending的migration文件删除就可以了.但是由于项目是共同开发的.我担心删除后会影响到以后的db部署.网上查到这些pending的migration需要执行一次
update migration(-Vobose)
当然了,部分pending的migration顺利更新到DB,但是有一个migration还是报错.提示就如同下方所示
Applying explicit migrations: [201805081508118_CreateOrganisation].
Applying explicit migration: 201805081508118_CreateOrganisation.
Applying automatic migration: 201805081508117_CreateOrganisation_AutomaticMigration.
System.Data.SqlClient.SqlException (0x80131904): There is already an object named 'Answers' in the database.
好奇怪我没看到我的migration文件中有类似于201805081508117_xxxxx_AutomaticMigration
这种文件, 那么为什么update database的时候需要执行一次explicit migration,和一次automatic migration呢?
我检查了我的configuration文件,显示已经关闭了automatic migration
public Configuration()
{
AutomaticMigrationsEnabled = false;
AutomaticMigrationDataLossAllowed = false;
}
于是没有办法,只能上网查找解决方案.
问题排查
首先必须了解什么是EF的两种migration方式
automatic migration
简而言之就是可以在你加入一个model后运行application, EF会自动将这个实体类更新到相应的DB中,无需你做其他的操作.但是如果你是对于一个已经存在的model实体类的属性进行修改, 这种模式无法自动更新到DB.
code base migration
这种migration是我项目中用的方式.这种方式相比较前者更加灵活, 可以通过配置来进行灵活的migration以及revert.主要使用命令行的方式进行操作DB,详细的资料可以去文章下方找对应的链接细看.
那么目前来看我们项目中使用的是code-based migration. 但是为何会在命令行出现automatic的字样? 我还是没有解决这个问题. 后来我在Stack Overflow上查到一个问题现象和我一样的,但是没有相关的回答. (后期我在解决了问题后也回去解答了问题).
此外找到了一篇资料跟我的情况还算类似. 其中提问者自问自答了问题, 说是项目进行阶段, 不知道什么原因,
automatic migration和code-based migration被混合使用了
.其中automatic migration的资源文件resx
文件里面有个source
属性会导致在update-database的时候必须执行一次automatic migration...
好吧回来看看这个方案能否解决我的问题, 我将出现问题的migration的资源文件的source属性remove掉之后, 再次执行update-migration.
果然可以将pending的migration顺利update到db的_MigrationHistory当中了...
问题算是解决...
参考资料
Stack Overflow:
解决问题的链接
https://stackoverflow.com/questions/12341470/update-database-tries-to-do-an-automatic-migration-even-with-automatic-migration
我的Stack Overflow回答
https://stackoverflow.com/questions/50679792/disable-automatic-migrations-in-entity-framework/54320652?noredirect=1#comment95460550_54320652
code base migration && automatic migration
http://www.entityframeworktutorial.net/code-first/code-based-migration-in-code-first.aspx
others
https://coding.abel.nu/2012/02/ef-migrations-and-a-merge-conflict/
希望以上内容能够帮助到遇到同样问题的你.如有其它思路可以随时联系我.
【Entity Framework】disable automatic migration, 执行update-migration仍然会显示有automatic migration的更多相关文章
- Entity Framework 在MySQL中执行SQL语句,关于参数问题
在Entity Framework中添加MySQL模型,在写代码的过程中需要直接执行SQL语句. 在SQL语句中用到了@curRank := 0 这样在SQL语句中定义参数,同时还会有传入参数:ai. ...
- Entity Framework 6 暂停重试执行策略
EF6引入一个弹性连接的功能,也就是允许重新尝试执行失败的数据库操作.某些复杂的场景中,可能需要启用或停用重试执行的策略,但是EF框架暂时尚未提供直接的设置开关,将来可能会加入这种配置.幸运的是,很容 ...
- ASP.NET Core 快速入门(Razor Pages + Entity Framework Core)
引子 自从 2009 年开始在博客园写文章,这是目前我写的最长的一篇文章了. 前前后后,我总共花了 5 天的时间,每天超过 3 小时不间断写作和代码调试.总共有 8 篇文章,每篇 5~6 个小结,总截 ...
- Asp.Net MVC 模型(使用Entity Framework创建模型类) - Part.1
这篇教程的目的是解释在创建ASP.NET MVC应用程序时,如何使用Microsoft Entity Framework来创建数据访问类.这篇教程假设你事先对Microsoft Entity Fram ...
- MVC5 Entity Framework学习之实现继承
之前你已经学习了怎样处理并发异常,在本节中你将学习怎样实现继承. 在面向对象的编程中,你能够使用继承来重用代码.接下来你将改动Instructor和Student类,让它们派生自Person基类,该基 ...
- Asp.Net MVC 模型(使用Entity Framework创建模型类)
这篇教程的目的是解释在创建ASP.NET MVC应用程序时,如何使用Microsoft Entity Framework来创建数据访问类.这篇教程假设你事先对Microsoft Entity Fram ...
- MVC5 Entity Framework学习之实现主要的CRUD功能
在上一篇文章中,我们使用Entity Framework 和SQL Server LocalDB创建了一个MVC应用程序,并使用它来存储和显示数据.在这篇文章中,你将对由 MVC框架自己主动创建的CR ...
- C# Entity Framework查询小技巧 NoTracking
在使用Entity Framework做查询的时候,如果只需要显示,而不用保存实体,那么可以用AsNoTracking()来获取数据. 这样可以提高查询的性能. 代码如下: var context = ...
- Entity Framework Core 生成跟踪列
本文翻译自<Entity Framework Core: Generate tracking columns>,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 注意:我使用的是 ...
随机推荐
- linux 的基本操作(linux系统的日常管理)
系统的日常管理 笔者在前面介绍的内容都为linux系统基础类的,如果你现在把前面的内容全部很好的掌握了,那最好了.不过笔者要说的是,即使你完全掌握了,你现在还是不能作为一名合格的linux系统管理员的 ...
- ubuntu apt 软件源的更改
在ubuntu上面安装软件一般都使用 apt安装 在ubuntu下面有一个源列表,源列表里面都是一些网站信息,每条网址就是一个源,这个地址指向的数据标识着这台服务器上有哪些软件可以用 编辑源命令: s ...
- openshift 配置 bitbucket 的webhook
参考 https://docs.openshift.org/latest/dev_guide/builds/triggering_builds.html oc set triggers bc < ...
- elk-插件(head、X-pack)(五)
一.修改ES配置,允许REST跨源操作ES服务器,添加以下2个配置,并重启ES. http.cors.enabled: true #如果启用了 HTTP 端口,那么此属性会指定是否允许跨源 REST ...
- 个人小爱好:Operating System: three easy pieces第6章第5节——总结
总结 我们讨论了实现CPU虚拟化的部分底层机制,及我们统称为直接执行(direct execution)的一组技术.基本的思想十分简单明了:直接在CPU上运行你想运行的代码,但是你先得确保将硬件设置好 ...
- C# 封装winio.dll 驱动级按键鼠标操作模拟
using System;using System.Collections.Generic;using System.Text;using System.Runtime.InteropServices ...
- ML.NET 0.9特性简介
ML.NET 0.9已于上周发布,距离上次0.8版本的发布只有一个多月,此次增加的新特性主要包括特征贡献计算,模型可解释性增强,ONNX转换对GPU的支持,Visual Studio ML.NET项目 ...
- 最全的MonkeyRunner自动化测试从入门到精通(4)
Android Sdk环境变量配置步骤一:我们进行再eclipse中下载sdk来进行使用. 在安装ADT插件完成之后,在eclipse的菜单界面会多一个ADT的管理器,如下图,点击进入到安卓API安装 ...
- 图像分类(一)GoogLenet Inception_V1:Going deeper with convolutions
论文地址 在该论文中作者提出了一种被称为Inception Network的深度卷积神经网络,它由若干个Inception modules堆叠而成.Inception的主要特点是它能提高网络中计算资源 ...
- 在window 2008r2开发服务器上安装MSMQ消息队列
1.打开”服务器管理器“------”功能“-------”添加功能“,勾选”消息队列“,如下图: 如果之前已经勾选,则忽略此步. 2.”功能“------”消息队列“------”专有对列“---- ...