关于EF框架EntityState的几种状态

在使用EF框架时,我们通常都是通过调用SaveChanges方法把增加/修改/删除的数据提交到数据库,但是上下文是如何知道实体对象是增加、修改还是删除呢?答案是通过EntityState的枚举值来判断的。也就是说在操作数据库时,EF会根据EntityState这个枚举检测到实体的状态,然后执行相应的增/删/改操作。

 

在使用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() 方法。

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

复制代码
复制代码
        [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);
        }
复制代码
复制代码
复制代码
复制代码
       [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");
        }
复制代码
复制代码

 

posted @   竹林听雨行  阅读(258)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示