gpt4 book ai didi

Laravel 批量更新多条数据的示例

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 31 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Laravel 批量更新多条数据的示例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

引言 。

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

任务要求 。

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

Laravel 批量更新多条数据的示例

方法1 。

我首先想到的是利用where()方法查出user id和is read符合条件的notices,然后利用foreach循环和save()更新数据表.

?
1
2
3
4
5
6
7
8
$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语句就搞定这个问题 。

?
1
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和要修改字段名 。

?
1
2
3
4
5
6
publish function update_batch_one( $table , $user_id , $column )
{
  $q = "UPDATE" . $table .SET. $column . "=1WHEREuser_id=" . $user_id . "AND" . $column . "=0" ;
 
  return DB::update(DB::raw( $q )
}

总结归纳 。

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.

原文链接:http://blog.qiji.tech/archives/16653 。

最后此篇关于Laravel 批量更新多条数据的示例的文章就讲到这里了,如果你想了解更多关于Laravel 批量更新多条数据的示例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com