EF-在不使用foreach循环的情况下更新数据库中的多行 [英] EF - Update multiple rows in database without using foreach loop

查看:323
本文介绍了EF-在不使用foreach循环的情况下更新数据库中的多行的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我的测试代码:

using (var db = new MyDbContext())
{
  string fromUser = ""; //sender
  string toUser = ""; //receiver

  var messages = db.Message.Where(x => x.FromUser == fromUser && x.ToUser == toUser)
                 .ToList();

  foreach (var message in messages)
  {
    message.IsRead = true;
    db.SaveChanges();
  }
}

我的问题:在这种情况下,还有另一种无需使用foreach循环即可更新数据库的方法吗?

My question: is there another way to update database without using foreach loop in that case?

p/s:我一直在参考这些问题,但是它们都不能解决我的问题:

p/s: I'd been reference these questions but all of them didn't solve my problem:

更新多行而不循环

推荐答案

您无需在每次迭代时都保存SaveChanges().那将多次击中数据库.试试:

You don't need to SaveChanges() on each iteration. That will hit the database multiple times. Try:

using (var db = new MyDbContext())
{
  string fromUser = ""; //sender
  string toUser = ""; //receiver
  var messages = db.Message.Where(x => x.FromUser == fromUser && x.ToUser == toUser)
                 .ToList();
  messages.ForEach(m => m.IsRead = true);
  db.SaveChanges();
}

这篇关于EF-在不使用foreach循环的情况下更新数据库中的多行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆