分享

关于EF框架EntityState的几种状态

 ThinkTank_引擎 2017-08-28

在使用EF框架时,我们通常都是通过调用SaveChanges方法把增加/修改/删除的数据提交到数据库,但是上下文是如何知道实体对象是增加、修改还是删除呢?答案是通过EntityState的枚举值来判断的。也就是说在操作数据库时,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() 方法。

通过修改/删除数据来检验一下该状态值,帮助理解:

  1. <span style="white-space:pre">    </span>[HttpPost]  
  2.        public ActionResult Edit(TestDataDB testdatadb)  
  3.        {  
  4.            if (ModelState.IsValid)  
  5.            {  
  6.                Console.WriteLine(db.Entry(testdatadb).State); //枚举值为Detached  
  7.                db.Entry(testdatadb).State = EntityState.Modified;  
  8.                Console.WriteLine(db.Entry(testdatadb).State); //枚举值为Modified  
  9.                db.SaveChanges();  
  10.                Console.WriteLine(db.Entry(testdatadb).State);//枚举值为Unchanged  
  11.                return RedirectToAction("Index");  
  12.            }  
  13.            return View(testdatadb);  
  14.        }  
  1. <span style="white-space:pre">    </span>[HttpPost, ActionName("Delete")]  
  2.         public ActionResult DeleteConfirmed(int id)  
  3.         {  
  4.             TestDataDB testdatadb = db.TestDataDBS.Find(id);  
  5.             Console.WriteLine(db.Entry(testdatadb).State);//枚举值为Unchanged  
  6.             db.TestDataDBS.Remove(testdatadb);  
  7.             Console.WriteLine(db.Entry(testdatadb).State);//枚举值为Deleted  
  8.             db.SaveChanges();  
  9.             Console.WriteLine(db.Entry(testdatadb).State);//枚举值为Detached  
  10.             return RedirectToAction("Index");  
  11.         }  








    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多