首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用modelbuilder.HasKey()会导致实体框架新迁移出错

使用modelbuilder.HasKey()会导致实体框架新迁移出错
EN

Stack Overflow用户
提问于 2020-10-24 00:15:25
回答 1查看 251关注 0票数 0

我有一些将组合键作为主键的实体。我使用fluentApi配置它们来设置组合键,如下所示:

代码语言:javascript
运行
复制
modelBuilder.Entity<EntityWithCompositeKey>().HasKey(entity => new { entity.Property1, entity.Property2});

但是当我想在添加一个新的迁移之后更新数据库时,我得到了一个错误:

代码语言:javascript
运行
复制
System.InvalidOperationException: To change the IDENTITY property of a column, the column needs to be dropped and recreated.

经过一些挖掘,我意识到这是因为fluentApi中设置组合键的那些设置,我认为实体框架想要更改实体的主键来设置新的组合键,我得到了这个错误...我说的对吗?我哪里错了?

我无法更新我的数据库,因为这个错误,每次我需要删除迁移文件夹和数据库并重新创建它们,以便新的更改可以发生,这变得如此恼人,因为我们越来越接近生产。

我使用的是实体框架5rc1和Asp.Net核心3.1

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-27 11:13:53

更新列的主键时,需要在不删除迁移文件的情况下删除迁移记录中的migrationBuilder.AlterColumn方法。这是初始记录。

然后我添加一个实体并重新迁移。删除Up方法中的migrationBuilder.AlterColumn

数据库中的密钥被更改。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64503683

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档