Laravel 批量更新多条数据

本文介绍使用Laravel框架批量更新数据的方法,对比逐条更新与SQL语句一次性更新的效率,给出实用代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

引言
最近在写任务中,碰到一个问题,需要批量更新多条数据,但是Laravel没有提供这样的方法,Google了一些方法,刚好借着任务来举例说明一下。
任务要求

任务是一个简单的清除未读通知的API,其实就是把通知表中符合user_id 和 is_read = 0 的行中的 is_read改为1(0代表未读,1代表已读)。

1.png

方法1
我首先想到的是利用where()方法查出user_id和is_read符合条件的notices,然后利用foreach循环和save()更新数据表。
$notices = Notice::where(‘user_id’, $userId)
->where(‘is_read’, 0)
->get(); //得到user_id 和 is_read 符合的notices

foreach($notices as $notice) {
  $notice->is_read = 1;
  $notice->save();
}            //更新数据表

这个方法确实可行,可是每次遍历都会和数据库进行通讯,当数据量很大的时候,响应速度就会很慢,也非常的浪费资源。
方法2
当我去Google一篇博文启发了我:Laravel一次更新多条记录,批量更新的方法
其实可以利用一条数据库的SQL语句就搞定这个问题
UPDATE notices SET is_read = 1 WHERE user_id = 1 AND is_read =0

一次数据通讯,加快了响应速度又减少资源浪费,那么我可以这样写
$notices = DB::update(DB::raw(“UPDATE notices SET is_read = 1 WHERE user_id = 1 AND is_read =0”));
$notices的返回值是更改的数据行数

我们以后的应用中会有很多种类似的任务,像是忽略一些通知、已读一些消息等等,为了代码的复用,我们可以写一个方法,传入表名、user_id和要修改字段名
publish function update_batch_one($table, $user_id, $column)
{
q = " U P D A T E " . q ="UPDATE". q="UPDATE".table.SET. c o l u m n . " = 1 W H E R E u s e r i d = " . column."=1WHEREuser_id=". column."=1WHEREuserid=".user_id.“AND”.$column."=0";

return DB::update(DB::raw($q)
}

总结归纳
这两个方法都只能解决一些特定的问题,但是提供了一种思路,有时候用SQL语句可以很方便、简单的操作数据表,如果我们需要根据不同的条件,批量肯定多条数据的多条信息那么就需要用SQL的WHEN THEN方法了,具体思路就是在我上边贴出来的地址里。

作者:小样面
链接:https://www.jianshu.com/p/8c5f0cadd933
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值