• 关于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");
            }
  • 相关阅读:
    不同指针类型的转换
    dt7.0百度熊掌当天主动推送方法
    腾讯视频信息数据爬虫开发【核心爬虫代码】
    seo与python大数据结合给文本分词并提取高频词
    Python经典算法-猴子吃桃-思路分析
    猜数游戏-人机对战-经典的randint使用
    python模拟双色球大乐透生成算法
    python打造批量关键词排名查询工具
    python开发全自动网站链接主动提交百度工具
    centos下shell脚本kill掉mysql锁表进程【笔记】
  • 原文地址:https://www.cnblogs.com/codedisco/p/12568401.html
Copyright © 2020-2023  润新知