• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Laravel 批量更新多条数据的示例

    引言

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

    任务要求

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

    方法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 ="UPDATE".$table.SET.$column."=1WHEREuser_id=".$user_id."AND".$column."=0";
     
     return DB::update(DB::raw($q)
    }

    总结归纳

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

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

    您可能感兴趣的文章:
    • Laravel框架学习笔记之批量更新数据功能
    • laravel实现批量更新多条记录的方法示例
    • Laravel实现批量更新多条数据
    上一篇:PHP开发实现微信退款功能示例
    下一篇:PHP命令空间namespace及use的用法小结
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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