EF如何直接更新数据-创新互联

这篇文章主要介绍了EF如何直接更新数据,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

创新互联服务项目包括睢阳网站建设、睢阳网站制作、睢阳网页制作以及睢阳网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,睢阳网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到睢阳省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

EF中会为每个 管理的 实体对象 创建一个代理包装类对象,其中会跟踪 实体对象 的状态和每个属性的状态;

一、通常使用EF更新的方式,先查询出要修改的数据,然后再修改新的值;实体对象被修改的属性 在 代理包装类对象里 的对应属性状态会被修改记录下修改状态,等到调用SaveChanges时,EF会遍历其管理的每个实体对象,并根据其 包装类对象 的状态,生成增删改查sql语句并执行;

此例中修改操作,会生成 修改的sql语句(注意:此处只为修改过的属性生成sql语句),最后执行。

缺点:修改先还要查询,难受~~~~

//------------------------------------------------------

//1.先查询要修改的原数据

Models.BlogArticle modelNew = db.BlogArticles.Where(a => a.AId == model.AId).FirstOrDefault();

//2.设置修改后的值

modelNew.ATitle = model.ATitle;

modelNew.AContent = model.AContent;

modelNew.ACate = model.ACate;

//3.跟新到数据库

db.SaveChanges();

二、为避免先查询数据库,可以直接将 被修改的实体对象 添加到 EF中管理(此时为附加状态Attached),并手动设置其为未修改状态(Unchanged),同时设置被修改的实体对象 的 包装类对象 对应属性为修改状态。

优点:修改前不需要查询数据库。

//-----------------------------------------------------

//0.0创建修改的 实体对象

Models.BlogArticle model = new BlogArticle();

model.AId = 12;

model.ATitle = "新的数据";

model.AContent = "新的数据~~~~~";

//0.1添加到EF管理容器中,并获取 实体对象 的伪包装类对象

DbEntityEntry entry = db.Entry(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();

感谢你能够认真阅读完这篇文章,希望小编分享的“EF如何直接更新数据”这篇文章对大家有帮助,同时也希望大家多多支持创新互联建站,关注创新互联网站制作公司行业资讯频道,更多相关知识等着你来学习!

创新互联www.cdcxhl.cn,专业提供香港、美国云服务器,动态BGP最优骨干路由自动选择,持续稳定高效的网络助力业务部署。公司持有工信部办法的idc、isp许可证, 机房独有T级流量清洗系统配攻击溯源,准确进行流量调度,确保服务器高可用性。佳节活动现已开启,新人活动云服务器买多久送多久。


本文标题:EF如何直接更新数据-创新互联
网页路径:http://pwwzsj.com/article/ceeche.html