在我的EF5代码优先模型中,如果数据库设置了主键,则创建新记录的效果会更好。我正在使用Guid作为主键,如果设置了DatabaseGeneratedOption.Identity,SQL Server将始终创建uniqueidentifier

但是,这在我尝试为数据库初始种子时会引起问题。如果我在种子方法中设置了Guid,SQL Server将覆盖它。如果我没有设置Guid,则每次都会获得新的记录。建议使用预设的Guid为数据库设置种子并为我的正常操作设置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有一个重载,可让您指定 key

MSDN

因此,您需要为该方法提供自然键:

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

关于c# - 如何在Entity Framework 5代码中首先处理主键,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/17712416/

10-13 07:45
查看更多