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 相关文章推荐
8个出色的WordPress SEO插件收集
Feb 26 PHP
浅谈PHP中output_buffering
Jul 13 PHP
详解PHP序列化反序列化的方法
Oct 27 PHP
Zend Framework处理Json数据方法详解
Dec 09 PHP
php利用imagemagick实现复古老照片效果实例
Feb 16 PHP
PHP中file_put_contents追加和换行的实现方法
Apr 01 PHP
深入理解PHP的远程多会话调试
Sep 21 PHP
PHP实现的一致性Hash算法详解【分布式算法】
Mar 31 PHP
PHP自动生成缩略图函数的源码示例
Mar 18 PHP
laravel 解决Eloquent ORM的save方法无法插入数据的问题
Oct 21 PHP
PHP强制转化的形式整理
May 22 PHP
php array_map()函数实例用法
Mar 03 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 中的批处理的实现
2007/06/14 PHP
PHP高级对象构建 工厂模式的使用
2012/02/05 PHP
雄兵连第三季海报曝光,艾妮熙德成主角,蔷薇新造型
2021/03/09 国漫
jquery用get实现ajax在ie里面刷新不进入后台解决方法
2013/08/12 Javascript
node.js中的fs.linkSync方法使用说明
2014/12/15 Javascript
JS给Textarea文本框添加行号的方法
2015/08/20 Javascript
js实现select跳转菜单新窗口效果代码分享(超简单)
2015/08/21 Javascript
jquery实现倒计时效果
2015/12/14 Javascript
js中class的点击事件没有效果的解决方法
2016/10/13 Javascript
javascript prototype原型详解(比较基础)
2016/12/26 Javascript
分享vue里swiper的一些坑
2018/08/30 Javascript
一文快速了解JQuery中的AJAX
2019/05/31 jQuery
mpvue 页面预加载新增preLoad生命周期的两种方式
2019/10/17 Javascript
实例分析javascript中的异步
2020/06/02 Javascript
jQuery实现动态加载瀑布流
2020/09/01 jQuery
解决vue加scoped后就无法修改vant的UI组件的样式问题
2020/09/07 Javascript
[01:20]DOTA2 2017国际邀请赛冠军之路无止竞
2017/06/19 DOTA
如何解决tensorflow恢复模型的特定值时出错
2020/02/06 Python
Python交互环境下打印和输入函数的实例内容
2020/02/16 Python
基于Numba提高python运行效率过程解析
2020/03/02 Python
HTML5中form如何关闭自动完成功能的方法
2018/07/02 HTML / CSS
韩都衣舍天猫官方旗舰店:天猫女装销售总冠军
2017/10/10 全球购物
阿联酋网上花店:Ferns N Petals
2018/02/14 全球购物
澳大利亚最大的网上油画销售画廊:Direct Art Australia
2018/04/15 全球购物
世界经理人咨询有限公司面试
2014/09/23 面试题
软件缺陷的分类都有哪些
2014/08/22 面试题
儿科护士自我鉴定
2013/10/14 职场文书
会计电算化专业个人的自我评价
2013/11/24 职场文书
酒店led欢迎词
2014/01/09 职场文书
大学四年的个人自我评价
2014/01/14 职场文书
《在大海中永生》教学反思
2014/02/24 职场文书
2014年教育工作总结
2014/11/26 职场文书
2014年图书管理员工作总结
2014/12/01 职场文书
幼儿园教师个人工作总结2015
2015/05/12 职场文书
工作简报格式范文
2015/07/21 职场文书
解决Windows Server2012 R2 无法安装 .NET Framework 3.5
2022/04/29 Servers