EF直接更新数据(不需查询)
2013-11-14 14:31
246 查看
EF中会为每个 管理的 实体对象 创建一个代理包装类对象,其中会跟踪 实体对象 的状态和每个属性的状态;
一、通常使用EF更新的方式,先查询出要修改的数据,然后再修改新的值;实体对象被修改的属性 在 代理包装类对象里 的对应属性状态会被修改记录下修改状态,等到调用SaveChanges时,EF会遍历其管理的每个实体对象,并根据其 包装类对象 的状态,生成增删改查sql语句并执行; 此例中修改操作,会生成 修改的sql语句(注意:此处只为修改过的属性生成sql语句),最后执行。 缺点:修改先还要查询,难受~~~~
二、为避免先查询数据库,可以直接将 被修改的实体对象 添加到 EF中管理(此时为附加状态Attached),并手动设置其为未修改状态(Unchanged),同时设置被修改的实体对象 的 包装类对象 对应属性为修改状态。 优点:修改前不需要查询数据库。
一、通常使用EF更新的方式,先查询出要修改的数据,然后再修改新的值;实体对象被修改的属性 在 代理包装类对象里 的对应属性状态会被修改记录下修改状态,等到调用SaveChanges时,EF会遍历其管理的每个实体对象,并根据其 包装类对象 的状态,生成增删改查sql语句并执行; 此例中修改操作,会生成 修改的sql语句(注意:此处只为修改过的属性生成sql语句),最后执行。 缺点:修改先还要查询,难受~~~~
//1.先查询要修改的原数据 Models.BlogArticle modelNew = db.BlogArticles.Where(a => a.AId == model.AId).FirstOrDefault(); //2.设置修改后的值 modelNew.ATitle = "新的数据"; modelNew.AContent = "新的数据~~~~~~"; modelNew.ACate = 12; //3.跟新到数据库 db.SaveChanges();
二、为避免先查询数据库,可以直接将 被修改的实体对象 添加到 EF中管理(此时为附加状态Attached),并手动设置其为未修改状态(Unchanged),同时设置被修改的实体对象 的 包装类对象 对应属性为修改状态。 优点:修改前不需要查询数据库。
//0.0创建修改的 实体对象 Models.BlogArticle model = new BlogArticle(); model.AId = 12; model.ATitle = "新的数据"; model.AContent = "新的数据~~~~~"; //0.1添加到EF管理容器中,并获取 实体对象 的伪包装类对象 DbEntityEntry<Models.BlogArticle> entry = db.Entry<Models.BlogArticle>(model); //**如果使用 Entry 附加 实体对象到数据容器中,则需要手动 设置 实体包装类的对象 的 状态为 Unchanged** //**如果使用 Attach 就不需要这句 entry.State = System.Data.EntityState.Unchanged; //0.2标识 实体对象 某些属性 已经被修改了 entry.Property("ATitle").IsModified = true; entry.Property("AContent").IsModified = true; //3.跟新到数据库 db.SaveChanges();
相关文章推荐
- SharePoint 2010新手入门(2) -- 基本概念
- Adobe Illustrator CC下的插件开发之UI
- linux平台开发有用的一些知识点. 持续更新.
- endUpdates
- String,StringBuffer,StringBuilder的区别
- 黑马程序员:GUI介绍:布局管理器、Frame、事件监听机制、Action事件、鼠标键盘事件、菜单、jar包的双击执行
- 程序员应该学习的签名破解
- SDN无层网络与TCP/IP分层网络
- JAVA hashCode使用方法详解
- sccm2012 Client Uninstall
- 通过cell的UIButton获取UITableViewCell的行数及Cell数据
- 任务栏发送消息
- android下ListView的奇异异常大集合(持续更新)
- Pro Android学习笔记(五五):调试和分析(3):adb命令、模拟器控制台和StrictMode
- search or reseed identity columns in sqlserver 2008
- 修改phpMyAdmin使其能够管理多台远程MySQL服务器
- Insertion Sort List
- [winphone][C#] RSA加密与解密
- CityEngine中动态水的实现效果
- HTML5图表开发工具大全