实体框架需要外键= db.savechanges上的验证错误



我为我的公司实体提供了这些课程

    public class Company
    {
        public Company()
        {
            this.Users = new HashSet<User>();
            this.Tools = new HashSet<Tool>();
        }
        public int Id { get; set; }
        public string Name { get; set; }
        public string Address { get; set; }
        public virtual ICollection<User> Users { get; set; }
        public virtual ICollection<Tool> Tools { get; set; }
        [Required]
        public virtual CompanyGroup CompanyGroup { get; set; }
    }
    public class CompanyDto
    {
        public string Name { get; set; }
        public string Address { get; set; }
    }

在CompaniesController中,我添加了一个附加类,其中包含ID参数,以用于编辑/更新方法

    public class CompanyViewEditModel : CompanyDto {
        public int Id { get; set; }
    }

编辑方法看起来像:

        [HttpPost]
        public ActionResult Edit(CompanyViewEditModel companyViewModel)
        {
            if (ModelState.IsValid)
            {
                var company = db.Companies.Find(companyViewModel.Id);
                company.InjectFrom(companyViewModel);
                db.Entry(company).State = EntityState.Modified;
                db.SaveChanges();
                return RedirectToAction("Index");
            }
            return View(companyViewModel);
        }

注射方法来自ValueInjecter。

由于验证异常,一切都按预期工作,只有db.savechanges调用失败。有些人在挖掘异常时发现,他认为该公司无效,因为需要现场企业集团,但是如果我进行调试器,即使在调用呼叫的注入后,一切似乎都很好。相应的公司组在那里。

考虑更改模型,因为您不必根据需要标记导航属性。而是添加像这样的fk。

public class Company
{
    public Company()
    {
        this.Users = new HashSet<User>();
        this.Tools = new HashSet<Tool>();
    }
    public int Id { get; set; }
    public string Name { get; set; }
    public string Address { get; set; }
    public int CompanyGroupId { get; set; }
    public virtual ICollection<User> Users { get; set; }
    public virtual ICollection<Tool> Tools { get; set; }
    public virtual CompanyGroup CompanyGroup { get; set; }
}

最新更新