我有一个非常简单的模型:
public class Item : DbEntity
{
public string Name {get;set;}
public int Quantity {get;set;}
public virtual Category Category {get;set;}
}
public class Category : DbEntity
{
public string Name {get;set;}
}
我使用以下方法保存并提交对数据库的更改:
public void SaveEntity<TEntity>(TEntity entity) where TEntity : DbEntity
{
if (entity.Id.Equals(Guid.Empty))
_context.Set<TEntity>().Add(entity);
else
_context.Entry(entity).State = System.Data.EntityState.Modified;
_context.SaveChanges();
}
public void DeleteEntity<TEntity>(TEntity entity) where TEntity : DbEntity
{
_context.Set<TEntity>().Remove(entity);
_context.SaveChanges();
}
这些保存和删除方法驻留在 Repository 中,这个 Repository 是 Ninjected,因此它应该在整个应用程序生命周期中保持恒定状态。这是一种久经考验的方法,它一直对我有用。现在由于某种原因,当我这样做时:
[HttpPost]
public ActionResult Edit(MenuItemViewModel vm)
{
if (ModelState.IsValid)
{
// TODO: Add ViewModel Logic
vm.MenuItem.Category = _repository.Categories.FirstOrDefault(x => x.Id.Equals(vm.SelectedCategory));
try
{
// TODO: Add Save Logic
_repository.SaveEntity(vm.MenuItem);
TempData["success"] = true;
TempData["message"] = String.Format("Saved {0} Successfully", vm.MenuItem.Description);
}
catch (Exception ex)
{
TempData["error"] = true;
TempData["message"] = "Error Occured";
}
return _redirectTo;
}
return View("Shape", vm);
}
视图部分很简单,只有 and 的一些字段Name
,Quantity
这Category
是一个Drop Down
包含所有类别名称 asText
和 id as的框Value
,它被发送回存储库所在的服务器,并收集新的Category
并将其分配给实体。
出于某种原因,这只是没有对数据库进行任何更改,前后断点,当我在检查数据库后中断时,它没有改变!
任何人都可以看到阻止它更新的愚蠢的小错误。
编辑
刚刚阅读了这篇StackOverflow 帖子,我拿起了上面说的部分,你先附加它然后编辑它,因为当调用附加时,你用Unchanged
状态调用它,然后当你修改它时,当你调用时更改将被保存SaveChanges()
.
跟这有关系吗?!
更新
好吧,一些有趣的消息,我逐步执行该SaveEntity
方法,在我跳过SaveChanges()
我再次检查上下文,它表明它已被更新?!我重定向到另一个控制器和操作的事实是否会影响结果或表修改?我不认为问题出在SaveEntity
方法上!!
最近更新
我更改了的模型Item
并简单地添加了public Guid CategoryId {get;set;}
简单地更改Category
为打开的行Cascade On Delete
。现在,当我尝试时出现此错误SaveChanges
:
发生参照完整性约束冲突:定义参照约束的属性值在关系中的主体对象和从属对象之间不一致。