为什么在使用DbSet.Add()时无法添加新创建的主体实体?

时间:2019-08-14 14:49:42

标签: c# entity-framework entity-framework-core

我有两堂课,他们是一对一的关系

public class Car
{
    public long Id { get; set; }
    public string Name { get; set; }
    public long CompanyId { get; set; }
    public Company Company { get; set; }
}

public class Company
{
    public long Id { get; set; }
    public string Name { get; set; }
    public Car Car { get; set; }
}

,假设我已经向Company表添加了一条记录(ID = 1),所以现在我想添加新的Car记录为

Car c = new Car { Name = "car1" };
c.CompanyId = 1;
context.Cars.Add(c);
context.SaveChanges();

上面的方法行得通,我可以,但是,如果尝试以下方法,则行不通并抛出异常(无法添加显式值来标识列:

Car c = new Car { Name = "car1" };
Company com = new Company { Id = 1 };
c.Company = com;
context.Cars.Add(c);
context.SaveChanges();

那么为什么DbSet.Add()认为我要添加新的公司记录?难道说出Company表中已经有一个ID为1的公司记录是足够聪明的吗?

2 个答案:

答案 0 :(得分:1)

这是因为默认情况下,当您在两个 new 对象之间创建关系时,实体框架会尝试将两个对象及其之间的关系添加到数据库中。您可以通过以下方式阻止添加子对象:

context.Entry(com).State = EntityState.Detached

或者您可以尝试

Car c = new Car { 
    Name = "car1",
    Company = context.Companies.First(x => x.Id == 1)
};

context.Cars.Add(c);
context.SaveChanges();

答案 1 :(得分:1)

DbContext实例将实体上的关系添加为数据库中的已添加(新)项,这些更改将在持久保存更改后添加(SaveChanges)。您可以将任何未更改的实体手动更改回Unchanged状态。

Car c = new Car { Name = "car1" };
Company com = new Company { Id = 1 };
c.Company = com;
context.Cars.Add(c);

// mark the company as unchanged
context.Entry(com).State = EntityState.Unchanged;

context.SaveChanges();

或者,您可以在DbContext中查询Company的实例,并使用它,但这是对数据库的1次额外往返。这种方法的好处是代码可能更易于阅读/维护。