相关疑难解决方法(0)

如何使用EF 4.3中的复杂密钥使用AddOrUpdate对数据进行种子设定

我正在尝试使用一些测试数据来开发数据库.

context.People.AddOrUpdate(p => p.Id, people));用得很成功了.

我有另一个我需要播种的表,其中我不知道主键.

例如,我想基于First和Last名称匹配AddOrUpdate.

我不确定如何正确编写表达式.

context.People.AddOrUpdate(p => p.FirstName && p.LastName, people);
Run Code Online (Sandbox Code Playgroud)

显然不正确,但我希望它能传达我正在寻找的解决方案.

c# seed linq-expressions ef-migrations entity-framework-4.3

101
推荐指数
1
解决办法
3万
查看次数

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

在我的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; }
Run Code Online (Sandbox Code Playgroud)

示例种子方法:

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();
Run Code Online (Sandbox Code Playgroud)

c# sql entity-framework entity-framework-5

6
推荐指数
1
解决办法
5619
查看次数