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


Posted in PHP onNovember 27, 2017

引言

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

任务要求

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

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

方法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创建动态图像
Oct 09 PHP
Banner程序
Oct 09 PHP
中篇:安装及配置PHP
Dec 13 PHP
php获取汉字首字母的函数
Nov 07 PHP
php图片的二进制转换实现方法
Dec 15 PHP
Yii实现多数据库主从读写分离的方法
Dec 29 PHP
PHP+JS实现大规模数据提交的方法
Jul 02 PHP
PHP判断来访是搜索引擎蜘蛛还是普通用户的代码小结
Sep 14 PHP
PHP弱类型的安全问题详细总结
Sep 25 PHP
Thinkphp实现短信验证注册功能
Oct 18 PHP
PHP CURL采集百度搜寻结果图片不显示问题的解决方法
Feb 03 PHP
php封装单文件上传到数据库(路径)
Oct 15 PHP
PHP开发实现微信退款功能示例
Nov 25 #PHP
PHP微信企业号开发之回调模式开启与用法示例
Nov 25 #PHP
PHP递归实现汉诺塔问题的方法示例
Nov 25 #PHP
PHP基于curl post实现发送url及相关中文乱码问题解决方法
Nov 25 #PHP
php图片合成方法(多张图片合成一张)
Nov 25 #PHP
PHP简单实现二维数组的矩阵转置操作示例
Nov 24 #PHP
PHP实现图的邻接矩阵表示及几种简单遍历算法分析
Nov 24 #PHP
You might like
解析PHP中empty is_null和isset的测试
2013/06/29 PHP
PHP中返回引用类型的方法
2015/04/03 PHP
php实现的xml操作类
2016/01/15 PHP
CodeIgniter扩展核心类实例详解
2016/01/20 PHP
PHP入门教程之正则表达式基本用法实例详解(正则匹配,搜索,分割等)
2016/09/11 PHP
Redis使用Eval多个键值自增的操作实例
2016/11/04 PHP
PHP反射学习入门示例
2019/06/14 PHP
gearman中任务的优先级和返回状态实例分析
2020/02/27 PHP
深入理解javascript中defer的作用
2013/12/11 Javascript
JavaScript简单实现鼠标拖动选择功能
2014/03/06 Javascript
AngularJS HTML编译器介绍
2014/12/06 Javascript
javascript实现全角与半角字符的转换
2015/01/07 Javascript
asp.net+jquery.form实现图片异步上传的方法(附jquery.form.js下载)
2016/05/05 Javascript
PHP7新特性简述
2017/06/11 Javascript
react-router JS 控制路由跳转实例
2017/06/15 Javascript
webpack+vue2构建vue项目骨架的方法
2018/01/09 Javascript
微信小程序实现天气预报功能
2018/07/18 Javascript
weui中的picker使用js进行动态绑定数据问题
2019/11/06 Javascript
python 算法 排序实现快速排序
2012/06/05 Python
Django查找网站项目根目录和对正则表达式的支持
2015/07/15 Python
Python Socket实现简单TCP Server/client功能示例
2017/08/05 Python
Python实现可自定义大小的截屏功能
2018/01/20 Python
使用PyInstaller将python转成可执行文件exe笔记
2018/05/26 Python
django DRF图片路径问题的解决方法
2018/09/10 Python
Python docutils文档编译过程方法解析
2020/06/23 Python
10个python爬虫入门实例(小结)
2020/11/01 Python
python中scrapy处理项目数据的实例分析
2020/11/22 Python
Feelunique澳大利亚:欧洲的化妆品零售电商
2019/12/18 全球购物
控制工程专业个人求职信
2013/09/25 职场文书
房地产出纳岗位职责
2013/12/01 职场文书
小学生推普周国旗下讲话稿
2014/09/21 职场文书
公务员四风问题对照检查材料整改措施
2014/09/26 职场文书
计划生育证明格式及范本
2014/10/09 职场文书
2016年五一劳动节专题校园广播稿
2015/12/17 职场文书
党校团干班培训心得体会
2016/01/06 职场文书
Python 内置函数速查表一览
2021/06/02 Python