Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/fortran/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Linq to sql 如何使用Linq更新表中的多行_Linq To Sql - Fatal编程技术网

Linq to sql 如何使用Linq更新表中的多行

Linq to sql 如何使用Linq更新表中的多行,linq-to-sql,Linq To Sql,我正在使用以下代码更新活动的UserSession列。如果ExpiryTimeStamp小于当前日期,下面的代码将返回记录。 然后将表中返回的记录的UserSession列更新为0。 .现在我希望如果有100条记录被返回,那么这些记录应该一次更新,而不是使用FoREach。在林克有可能吗 CacheDataDataContext db = new CacheDataDataContext(); var data = (from p in db.Activities

我正在使用以下代码更新活动的UserSession列。如果ExpiryTimeStamp小于当前日期,下面的代码将返回记录。 然后将表中返回的记录的UserSession列更新为0。 .现在我希望如果有100条记录被返回,那么这些记录应该一次更新,而不是使用FoREach。在林克有可能吗

CacheDataDataContext db = new CacheDataDataContext();
                var data = (from p in db.Activities
                            where p.ExpiryTimeStamp < DateTime.Now
                            select p).ToList();
                data.ForEach(ta => ta.UserSession = "0");
                db.SubmitChanges();
cachedatacontext db=new cachedatacontext();
var数据=(来自数据库活动中的p
其中p.ExpiryTimeStampta.UserSession=“0”);
db.SubmitChanges();

简言之,否:Linq-2-sql不会立即进行批量更新

(我不确定你的foreach是否会像你写的那样工作——我不这么认为——但这是类似的,并且会起作用)

但是,即使您这样做,Linq-2-sql也会将每条记录的update语句发送到数据库。因此,以您返回的100条记录为例,您将获得100条发送到数据库的单独更新

foreach (var x in data)
{x.UserSession = "0";}
db.SubmitChanges()