当我第一次在项目中运行Enable-Migrations
时,它在项目根目录下创建了一个Migrations
文件夹。然后,我将Migrations
文件夹移动到我的Data
文件夹下,其中包含上下文和模型等。然后我在已经应用的迁移中更正了名称空间。
然后我尝试使用Add-Migration IdToLong
进行第三次迁移,我收到错误消息:
无法生成显式迁移,因为以下内容 显式迁移正在等待审核:[201703061039495_Initial, 201703061159110_ContactRequest。应用挂起的显式迁移 在尝试生成新的显式迁移之前。
我能想到的唯一原因是EF已存储了连接字符串位置的相对路径,并且该路径现在无用。我看到几个报告,当无法连接到数据库时,EF显示相同的消息。
EF的这个隐藏存储/配置违背了我们使用EF Core移动的地方,我真的希望这个问题不会发生在那里。
为了解决我的问题,当我移动Migrations
以便EF再也看不到我已经应用了这些迁移时,更改或未更改的内容是什么?
答案 0 :(得分:4)
移动迁移时,您可能(可能)更改了对象的命名空间。此命名空间用作__MigrationHistory表中ContextKey列的默认值。所以现在当EF检查哪些迁移已经应用时,它将与旧的迁移不匹配。
如果这是您的问题,您可以通过以下两种方式解决问题:
1)运行脚本以重命名上下文键以匹配新的命名空间:
UPDATE [dbo].[__MigrationHistory]
SET [ContextKey] = 'New_Namespace.Migrations.Configuration'
WHERE [ContextKey] = 'Old_Namespace.Migrations.Configuration'
2)将旧的上下文密钥硬编码到迁移配置构造函数中:
public Configuration()
{
AutomaticMigrationsEnabled = false;
ContextKey = "Old_Namespace.Migrations.Configuration";
}