EF MYSQL批量更新_EF6学习笔记十二:Update操作、批量数据操作

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

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

Update操作

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

眼熟一下平时的Update

961ddebeb323a10fe0623af514929fc1.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

// 一般的修改

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

48304ba5e6f9fe08f3fa1abda7d326ab.png

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

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

961ddebeb323a10fe0623af514929fc1.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

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

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

Product p = new Product

{

Id = id,

Name = "娃哈哈",

AddTime = DateTime.Now,

Price = 3,

Unit = "瓶"

};

Console.WriteLine(ctx.Entry(p).State); // Detached

ctx.Products.Attach(p); // 这里报错

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值