6

在我的 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();
4

1 回答 1

8

AddOrUpdate 有一个允许你指定键的重载

来自MSDN

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

context.Record.AddOrUpdate(c => c.RecordName, new Record()
            {
                RecordName = "New Record",
                Created = DateTime.UtcNow,
                Updated = DateTime.UtcNow,
             })
于 2013-07-18T09:08:03.723 回答