我正在使用以下代码在List<string>
中存储connectionID列表:
List<string> connectionIds =
connectedUsers.Where(x => x.UserId == userId).Select(x => x.ConnectionId).ToList();
我需要更新数据库,以便在找到相应的ID时将连接状态设置为false
。到目前为止,我使用以下代码:
if (connectionIds.Any())
{
foreach (string connectionId in connectionIds)
{
Connection curConn = db.Connection.FirstOrDefault(x => x.ConnectionID == connectionId);
if (curConn != null)
curConn.Connected = false;
db.SaveChanges();
}
}
但是,这会为每个连接调用DB ...有没有简单的方法来更简单地更新连接?
答案 0 :(得分:2)
您可以使用Contains方法。这将导致单个查询以加载连接对象。获得查询结果后,循环结果以更新Connected
标志,然后保存更改。
List<string> connectionIds = ...;
if (connectionIds.Any()) {
var data = db.Connection
.Where(x => connectionIds.Contains(x.ConnectionID))
.ToList();
foreach (var item in data) {
item.Connected = false;
}
db.SaveChanges();
}
答案 1 :(得分:0)
您希望使用EF在一个SQL语句中执行批量更新。 EF不直接支持这一点。有关可能的解决方案,请参阅here。