首页 > 解决方案 > 当 IDENTITY_INSERT 设置为 OFF 时,EF 无法为表“X”中的标识列插入显式值

问题描述

我必须将数据从一个数据库迁移到另一个数据库。应保留密钥。我将 EF 与自动生成的.dbmx文件一起使用。我已经阅读了许多类似问题的答案并遵循了这些建议:我确实IDENTITY_INSERT在插入条目之前完全打开;在数据库图上,我将列更改StoreGeneratedPatternNoneon Id(也尝试将相应的属性添加到Id属性中)。

这是我的代码:

var myEntity = new MyTable
{
    Id = 12345,
    Name = "Lorem ipsum",
    BrandId = brandId,      
};

MyContext.Database.ExecuteSqlCommand("SET IDENTITY_INSERT MY_TABLE_NAME ON");
MyContext.MyTable.Add(myEntity);
await MyContext.SaveChangesAsync(); //getting error here

在 Management Studio 中执行此操作时,它工作得很好。该问题仅在使用实体框架时出现。

我可以在 SQL Server Profiler 中看到INSERT_IDENTITY执行命令并且插入 SQL 带有Id列,但似乎没有执行,这看起来很奇怪。当我复制粘贴此 SQL 查询时,它工作得很好。

标签: c#entity-frameworkef-database-firstidentity-insert

解决方案


问题是 EDMX 和 Designer.cs 文件是在您编译之前生成的,当您从数据库生成架构并且不更改时。验证是针对那些文件中的内容运行的。他们希望启用 identify_insert 属性,因此当您在数据库中以编程方式禁用它时,EF 层会抛出您遇到的异常。基本上说-您的数据库与我的数据库不匹配。

老实说,以这种方式进行大表数据传输并不是 EF 的设计目的。您应该使用批量数据复制


推荐阅读