efcore 批量_EF6学习笔记十二:Update操作、批量数据操作

本文介绍了EFCore中Update操作的使用,包括如何更新实体、处理主键冲突、部分属性更新的方法,以及批量更新数据的操作。通过示例代码展示了如何实现单个实体和多个实体的更新,并探讨了使用EntityFrameWork.Extended库进行更高效的批量更新。
摘要由CSDN通过智能技术生成

要专业系统地学习EF前往《你必须掌握的Entity Framework 6.x与Core 2.0》这本书的作者(汪鹏,Jeffcky)的博客:https://www.cnblogs.com/CreateMyself/

数据操作CRUD,我们只说Update,因为在EF中Update有点复杂  后面我们说批量数据更新

Update操作

上下文没有提供Update方法,所以我们要更新操作一般都是将数据查询出来,修改实体属性的值,然后SaveChanges()就OK了

眼熟一下平时的Update

//一般的修改

var pro =ctx.Products.FirstOrDefault();

Console.WriteLine(JsonConvert.SerializeObject(pro));

Console.WriteLine(ctx.Entry(pro).State);//Unchanged//{"Order":null,"Name":"牙刷","Price":14.00,"Unit":"只","FK_Order_Id":"82903023-a7a6-4839-9caa-153ee9d00e65","Id":"1b25351c-3008-4d27-a9de-6749ec1d0845","AddTime":"2019-01-15T10:35:03.947"}

pro.Name = "牙刷2";

Console.WriteLine(ctx.Entry(pro).State);//Modified

var res =ctx.SaveChanges();

Console.WriteLine(res);//result:1

View Code

查询出来没做修改的实体,状态为Unchange,修改了属性值,状态变为Modified

现在要是我凭空new一个Product对象,id设置为数据库中某一个产品的Id,然后让上下文对这个新对象追踪,最后再修改实体状态为Modified,看看能不能修改

//数据库中存在的某一条数据的Id

string id = "b0465c73-a7ab-4135-9bf8-4ec85ac6b1e2";

Product p= newProduct

{

Id=id,

Name= "娃哈哈",

AddTime=DateTime.Now,

Price= 3,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值