本文涉及的相关问题,如果你的问题或需求有与下面所述相似之处,请阅读本文

  • [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 migrationhttp://www.entityframeworktutorial.net/code-first/code-based-migration-in-code-first.aspx

othershttps://coding.abel.nu/2012/02/ef-migrations-and-a-merge-conflict/


希望以上内容能够帮助到遇到同样问题的你.如有其它思路可以随时联系我.

【Entity Framework】disable automatic migration, 执行update-migration仍然会显示有automatic migration的更多相关文章

  1. Entity Framework 在MySQL中执行SQL语句,关于参数问题

    在Entity Framework中添加MySQL模型,在写代码的过程中需要直接执行SQL语句. 在SQL语句中用到了@curRank := 0 这样在SQL语句中定义参数,同时还会有传入参数:ai. ...

  2. Entity Framework 6 暂停重试执行策略

    EF6引入一个弹性连接的功能,也就是允许重新尝试执行失败的数据库操作.某些复杂的场景中,可能需要启用或停用重试执行的策略,但是EF框架暂时尚未提供直接的设置开关,将来可能会加入这种配置.幸运的是,很容 ...

  3. ASP.NET Core 快速入门(Razor Pages + Entity Framework Core)

    引子 自从 2009 年开始在博客园写文章,这是目前我写的最长的一篇文章了. 前前后后,我总共花了 5 天的时间,每天超过 3 小时不间断写作和代码调试.总共有 8 篇文章,每篇 5~6 个小结,总截 ...

  4. Asp.Net MVC 模型(使用Entity Framework创建模型类) - Part.1

    这篇教程的目的是解释在创建ASP.NET MVC应用程序时,如何使用Microsoft Entity Framework来创建数据访问类.这篇教程假设你事先对Microsoft Entity Fram ...

  5. MVC5 Entity Framework学习之实现继承

    之前你已经学习了怎样处理并发异常,在本节中你将学习怎样实现继承. 在面向对象的编程中,你能够使用继承来重用代码.接下来你将改动Instructor和Student类,让它们派生自Person基类,该基 ...

  6. Asp.Net MVC 模型(使用Entity Framework创建模型类)

    这篇教程的目的是解释在创建ASP.NET MVC应用程序时,如何使用Microsoft Entity Framework来创建数据访问类.这篇教程假设你事先对Microsoft Entity Fram ...

  7. MVC5 Entity Framework学习之实现主要的CRUD功能

    在上一篇文章中,我们使用Entity Framework 和SQL Server LocalDB创建了一个MVC应用程序,并使用它来存储和显示数据.在这篇文章中,你将对由 MVC框架自己主动创建的CR ...

  8. C# Entity Framework查询小技巧 NoTracking

    在使用Entity Framework做查询的时候,如果只需要显示,而不用保存实体,那么可以用AsNoTracking()来获取数据. 这样可以提高查询的性能. 代码如下: var context = ...

  9. Entity Framework Core 生成跟踪列

    本文翻译自<Entity Framework Core: Generate tracking columns>,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 注意:我使用的是 ...

随机推荐

  1. zepto.js的touch模块

     touch库实现了什么和引入背景 touch模块是基于zepto.js的. click事件在移动端上会有 300ms 的延迟,同时因为需要 长按 , 双触击 等富交互,所以我们通常都会引入类似 ze ...

  2. eclipse中的快捷键的使用

  3. mui APP与服务器之间的交互原理

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...

  4. Python学习之旅(八)

    Python基础知识(7):数据基本类型之元组.字典 一.元组 用括号把元素括起来中间用逗号隔开.用逗号分开一些值便可创建元组 1,2,3 结果: (1, 2, 3) 空元组可以用没有包含任何内容的两 ...

  5. 用友U8存货分类通过DataTable生成EasyUI Tree JSON

    <%@ WebHandler Language="C#" Class="InventoryClass" %> using System; using ...

  6. python全栈开发 * 15知识点汇总 * 180621

    #15 函数二 与 匿名函数1.dir() # 查看内置属性,将对象所有方法名放在另一个列表中.dic={"水果":"香蕉",'蔬菜':"土豆&quo ...

  7. H5的缓存 manifest

    H5里面的App Cache是由开发Web页面的开发者控制的,而不是由Native去控制的,但是Native里面的WebView也需要我们做一下设置才能支持H5的这个特性. 1.工作原理 写Web页面 ...

  8. java异常处理解决方案

    一.异常概念 Throwable类是Java中所有错误或异常的超类. 1.只有当对象是此类(或其子类)的实例时,才能通过Java虚拟机或着Java throw语句抛出.     2.只有此类或其子类才 ...

  9. Yarn vs npm: 你需要知道的一切(转)

    英文原文:https://www.sitepoint.com/yarn-vs-npm/ 译文:http://web.jobbole.com/88459/ Yarn 是 Facebook, Google ...

  10. 更新Xcode10与iOS12 遇到的bug:library not found for -lstdc++.6.0.9

    更新Xcode10与iOS12 遇到的bug:library not found for -lstdc++.6.0.9 解决办法:删除pod里导入的库文件,跑一下pod,再重新导入这些库文件,跑pod ...