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

 更新时间:2017年11月27日 09:24:38   作者:杨 浩国  
本篇文章主要介绍了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方法了,具体思路就是在我上边贴出来的地址里。

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

相关文章

  • PHP缩略图生成和图片水印制作

    PHP缩略图生成和图片水印制作

    这篇文章主要为大家详细介绍了PHP缩略图生成和图片水印制作过程,php实现水印添加与缩略图生成的相关步骤,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • 关于laravel模板中生成URL的几种模式总结

    关于laravel模板中生成URL的几种模式总结

    今天小编就为大家分享一篇关于laravel模板中生成URL的几种模式总结,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • Uchome1.2 1.5 代码学习 common.php

    Uchome1.2 1.5 代码学习 common.php

    这是uchome 用到的php代码,大家在学习编程的时候,可以看下当时比较成熟的一些cms系统,前提是你对程序比较熟悉啊,要不看了会打消学习积极性的。
    2009-04-04
  • php读取excel文件的简单实例

    php读取excel文件的简单实例

    这篇文章介绍了php读取excel文件的简单实例,有需要的朋友可以参考一下
    2013-08-08
  • PHP设计模式(四)原型模式Prototype实例详解【创建型】

    PHP设计模式(四)原型模式Prototype实例详解【创建型】

    这篇文章主要介绍了PHP设计模式:原型模式Prototype,结合实例形式详细分析了PHP原型模式Prototype的基本概念、功能、原理、实现方法与操作注意事项,需要的朋友可以参考下
    2020-05-05
  • ThinkPHP的SAE开发相关注意事项详解

    ThinkPHP的SAE开发相关注意事项详解

    这篇文章主要介绍了ThinkPHP的SAE开发相关注意事项,结合实例形式较为详细的分析了thinkPHP针对SAE开发的相关数据库、缓存、文件、图片、日志等操作注意事项,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-10-10
  • Codeigniter实现发送带附件的邮件

    Codeigniter实现发送带附件的邮件

    这篇文章主要介绍了Codeigniter实现发送带附件的邮件的方法,涉及Codeigniter中attach方法的使用技巧,非常具有实用价值,需要的朋友可以参考下
    2015-03-03
  • laravel 如何实现引入自己的函数或类库

    laravel 如何实现引入自己的函数或类库

    laravel 如何实现引入自己的函数或类库?今天小编就为大家解答一下在laravel中引入自己的函数或类库的方法,分享给大家,给大家做个参考,一起过来看看吧
    2019-10-10
  • php设计模式之抽象工厂模式分析【星际争霸游戏案例】

    php设计模式之抽象工厂模式分析【星际争霸游戏案例】

    这篇文章主要介绍了php设计模式之抽象工厂模式,结合星际争霸游戏案例形式分析了PHP抽象工厂模式的具体原理、使用技巧与相关操作注意事项,需要的朋友可以参考下
    2020-01-01
  • PHP自动补全表单的两种方法

    PHP自动补全表单的两种方法

    这篇文章主要介绍了PHP自动补全表单的两种方法,第一种从数据库中检索之后补全,第二种邮箱等纯前端的补全,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03

最新评论