EF会根据EntityState这个枚举检测到实体的状态,然后执行相应的增/删/改操作
该状态对应的值为以下五种:
Detached:对象存在,但未由对象服务跟踪。在创建实体之后、但将其添加到对象上下文之前,该实体处于此状态;
Unchanged:自对象加载到上下文中后,或自上次调用 System.Data.Objects.ObjectContext.SaveChanges() 方法后,此对象尚未经过修改;
Added:对象已添加到对象上下文,但尚未调用 System.Data.Objects.ObjectContext.SaveChanges() 方法;
Deleted:使用 System.Data.Objects.ObjectContext.DeleteObject(System.Object) 方法从对象上下文中删除了对象;
Modified:对象已更改,但尚未调用 System.Data.Objects.ObjectContext.SaveChanges() 方法。
<span style="white-space:pre"> </span>[HttpPost]
public ActionResult Edit(TestDataDB testdatadb)
{
if (ModelState.IsValid)
{
Console.WriteLine(db.Entry(testdatadb).State); //枚举值为Detached
db.Entry(testdatadb).State = EntityState.Modified;
Console.WriteLine(db.Entry(testdatadb).State); //枚举值为Modified
db.SaveChanges();
Console.WriteLine(db.Entry(testdatadb).State);//枚举值为Unchanged
return RedirectToAction("Index");
}
return View(testdatadb);
}
<span style="white-space:pre"> </span>[HttpPost, ActionName("Delete")]
public ActionResult DeleteConfirmed(int id)
{
TestDataDB testdatadb = db.TestDataDBS.Find(id);
Console.WriteLine(db.Entry(testdatadb).State);//枚举值为Unchanged
db.TestDataDBS.Remove(testdatadb);
Console.WriteLine(db.Entry(testdatadb).State);//枚举值为Deleted
db.SaveChanges();
Console.WriteLine(db.Entry(testdatadb).State);//枚举值为Detached
return RedirectToAction("Index");
}