加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 如何处理实体框架5中的主键代码优先

发布时间:2020-12-15 08:13:17 所属栏目:百科 来源:网络整理
导读:在我的EF5代码优先模型中,如果数据库设置主键,则创建新记录会更好.我使用Guid作为主键,如果设置了 DatabaseGeneratedOption.Identity,SQL Server将始终创建uniqueidentifier. 但是,当我尝试初始化数据库时,这会导致问题.如果我在种子方法中设置Guid,SQL Serv
在我的EF5代码优先模型中,如果数据库设置主键,则创建新记录会更好.我使用Guid作为主键,如果设置了 DatabaseGeneratedOption.Identity,SQL Server将始终创建uniqueidentifier.

但是,当我尝试初始化数据库时,这会导致问题.如果我在种子方法中设置Guid,SQL Server会覆盖它.如果我没有设置Guid,我每次都会得到一条新记录.使用预先设置的Guids为数据库设定种子并为我的正常操作设置DatabaseGeneratedOption.Identity的建议解决方案是什么?

示例类模型:

[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public Guid Id { get; set; }
public RecordName { get; set; }
public DateTime? Created { get; set; }
public DateTime? Updated { get; set; }

示例种子方法:

var record = new Record()
            {
                Id = new Guid("3B80725E-9550-4933-807F-C2FAA0942225"),RecordName = "New Record",Created = DateTime.UtcNow,Updated = DateTime.UtcNow,};
context.Record.AddOrUpdate(record);
context.SaveChanges();

解决方法

AddOrUpdate具有允许您指定密钥的重载

从MSDN起

所以你需要为方法提供自然键:

context.Record.AddOrUpdate(c => c.RecordName,new Record()
            {
                RecordName = "New Record",})

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读