EF直接更新数据(不需查询)
来源:互联网 发布:如何供货给淘宝 编辑:程序博客网 时间:2024/05/16 15:32
EF直接更新数据(不需查询)
EF中会为每个 管理的 实体对象 创建一个代理包装类对象,其中会跟踪 实体对象 的状态和每个属性的状态;
一、通常使用EF更新的方式,先查询出要修改的数据,然后再修改新的值;实体对象被修改的属性 在 代理包装类对象里 的对应属性状态会被修改记录下修改状态,等到调用SaveChanges时,EF会遍历其管理的每个实体对象,并根据其 包装类对象 的状态,生成增删改查sql语句并执行;
此例中修改操作,会生成 修改的sql语句(注意:此处只为修改过的属性生成sql语句),最后执行。
缺点:修改先还要查询,难受~~~~
1 //1.先查询要修改的原数据 2 Models.BlogArticle modelNew = db.BlogArticles.Where(a => a.AId == model.AId).FirstOrDefault(); 3 4 //2.设置修改后的值 5 modelNew.ATitle = "新的数据"; 6 modelNew.AContent = "新的数据~~~~~~"; 7 modelNew.ACate = 12; 8 9 //3.跟新到数据库10 db.SaveChanges();
二、为避免先查询数据库,可以直接将 被修改的实体对象 添加到 EF中管理(此时为附加状态Attached),并手动设置其为未修改状态(Unchanged),同时设置被修改的实体对象 的 包装类对象 对应属性为修改状态。
优点:修改前不需要查询数据库。
1 //0.0创建修改的 实体对象 2 Models.BlogArticle model = new BlogArticle(); 3 model.AId = 12; 4 model.ATitle = "新的数据"; 5 model.AContent = "新的数据~~~~~"; 6 7 //0.1添加到EF管理容器中,并获取 实体对象 的伪包装类对象 8 DbEntityEntry<Models.BlogArticle> entry = db.Entry<Models.BlogArticle>(model); 9 10 //**如果使用 Entry 附加 实体对象到数据容器中,则需要手动 设置 实体包装类的对象 的 状态为 Unchanged**11 //**如果使用 Attach 就不需要这句12 entry.State = System.Data.EntityState.Unchanged;13 14 //0.2标识 实体对象 某些属性 已经被修改了15 entry.Property("ATitle").IsModified = true;16 entry.Property("AContent").IsModified = true;17 18 //3.跟新到数据库19 db.SaveChanges();
http://www.cnblogs.com/jameszou/archive/2013/03/12/2956281.html
0 0
- EF直接更新数据(不需查询)
- EF直接更新数据(不需查询)
- EF直接更新数据(不需查询)
- EF直接更新数据的另一种方法(不需查询)
- EF 数据更新
- EF 查询数据
- EF 批量更新/删除数据
- EF 批量更新/删除数据
- ef更新数据库数据失败
- 经验总结16--EF局部更新数据
- EF实体中的数据修改更新
- [转]EF 批量更新/删除数据
- EF多表关联数据更新
- MVC+EF+easyui数据更新问题
- Entity Framework(EF)数据查询
- oracle 直接更新查询结果
- EF直接查询一张子表的注意事项
- EF查询
- java.lang.ClassCastException异常处理
- LeetCode | LRU Cache
- Ubuntu 网站服务器环境搭建
- Qt串口通信专题教程
- Tomcat映射外部资源,部署应用
- EF直接更新数据(不需查询)
- 《黑马程序员》 鼠标和键盘监听器 窗体事件 图形化管理界面 day22
- Debian ibus配置
- 我的WCF4 Rest Service及Entity Framework with POCO之旅(一)——创建一个基本的RESTful Service
- Debian安装的Chromium-browser中文显示不正常解决方法
- 黑马程序员 动态代理
- LeetCode | Median of Two Sorted Arrays
- CommonLisp环境搭建及HelloWorld
- IT零起步-CentOS6.4部署PPTPVPN服务器