ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

对EF中5种实体状态System.Data.EntityState的一点理解

2022-02-17 15:32:05  阅读:251  来源: 互联网

标签:状态 对象 Unchanged EF System 上下文 Data EntityState


System.Data.EntityState一共有五种状态

 分别是Added,Deleted,Modified,UnChanged,Detached下面给一个简单的解释

  • System.Data.EntityState.Added

在上下文中,而且对象是需要添加的状态

  • System.Data.EntityState.Deleted

在上下文中,而且对象是需要删除的状态

  • System.Data.EntityState.Modified

在上下文中,而且对象是需要修改的状态

  • System.Data.EntityState.UnChanged

在上下文中,对象没有任何状态

  • System.Data.EntityState.Detached

没有在上下文中,和ef上下文没有关联的状态

 

当调用SaveChanges的时候ef会根据这些状态响应到数据库去

使用ef查询出来的对象属于EntityState.UnChanged状态

Unchanged状态说明ef在上下文中,处于这种状态我们就可以很方便的对他进行删除,修改了

调用Add方法后对象属于EntityState.Added状态

 

 添加成功后,对象就处于Unchanged了

  

 有个有趣的想法我们先调用Add后在手动把状态修改成Unchanged看看能不能添加成功,我们的想法是不得行!因为是根据状态来操作数据库的

 

 哈哈果然如此!

调用Attach方法后对象属于EntityState.Unchanged状态

所以如果我们是一个新的对象进行cud操作通常情况下先把对象加入上下文后在进行操作

还可以直接使用oae.Entry(item).State = EntityState.Unchanged;这种方式修改状态

New的新对象属于EntityState.Detached状态

也就是对象没有在上下文中

例如我们随便弄一个对象然后获取他的状态看看,就是Detached状态

如果在这种状态下直接去进行,Remove,改变字段修改状态等

  1. //删除
  2. oae.Users.Remove(item);
  3. //改变字段状态
  4. oae.Entry(item).Property("UserName").IsModified = true;

就会报错:对象不在上下文中

改变字段状态报错:

删除之所以会报错其实可以看Remove方法的注释:在调用此方法之前,该实体必须以另一种状态存在于该上下文中

虽然Remove方法是吧状态修改为Deleted但是有个前提是对象必须以另外一种状态存在上下文中

因为我们对象是相当于是直接new的一个所以肯定不在上下文中,我们可以使用调用Attach方法之后在删除

可以看到Attach方法就是把对象以Unchanged状态附加到上下文,

当然我们还可以使用oae.Entry(item).State = EntityState.Unchanged;方式把对象以Unchanged状态附加到上下文,道理都一样

看看remove后的状态以及修改成Deleted了

所以我们在使用ef做curd操作的时候要注意对象的状态

标签:状态,对象,Unchanged,EF,System,上下文,Data,EntityState
来源: https://www.cnblogs.com/itjeff/p/15904813.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有