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+MSSQL分页的例子
Oct 09 PHP
ecshop 批量上传(加入自定义属性)
Mar 20 PHP
Memcached常用命令以及使用说明详解
Jun 27 PHP
zf框架的zend_cache缓存使用方法(zend框架)
Mar 14 PHP
destoon后台网站设置变成空白的解决方法
Jun 21 PHP
Laravel5中contracts详解
Mar 02 PHP
php在数组中查找指定值的方法
Mar 17 PHP
WAF的正确bypass
Jan 05 PHP
PHP微信PC二维码登陆的实现思路
Jul 13 PHP
实例介绍PHP中zip_open()函数用法
Feb 15 PHP
详解PHP PDO简单教程
May 28 PHP
PHP实现限制域名访问的实现代码(本地验证)
Sep 13 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
40年前的这部特摄片恐龙特级克塞号80后的共同回忆
2020/03/08 日漫
php通过前序遍历树实现无需递归的无限极分类
2015/07/10 PHP
ECSHOP在PHP5.5及高版本上报错的解决方法
2015/08/31 PHP
SeaJS入门教程系列之SeaJS介绍(一)
2014/03/03 Javascript
angularjs 源码解析之scope
2016/08/22 Javascript
js实现简单的碰壁反弹效果
2016/08/30 Javascript
js上下视差滚动简单实现代码
2017/03/07 Javascript
JavaScript+HTML5实现的日期比较功能示例
2017/07/12 Javascript
利用vue开发一个所谓的数独方法实例
2017/12/21 Javascript
JQuery实现table中tr上移下移的示例(超简单)
2018/01/08 jQuery
详解如何在vue项目中引入elementUI组件
2018/02/11 Javascript
安装Node.js并启动本地服务的操作教程
2018/05/12 Javascript
微信小程序实现折叠与展开文章功能
2018/06/12 Javascript
微信小程序实现即时通信聊天功能的实例代码
2018/08/17 Javascript
Vue.js实现双向数据绑定方法(表单自动赋值、表单自动取值)
2018/08/27 Javascript
原生js实现的金山打字小游戏(实例代码详解)
2020/03/16 Javascript
[00:14]PWL:老朋友Mushi拍VLOG与中国玩家问好
2020/11/04 DOTA
使用Python发送邮件附件以定时备份MySQL的教程
2015/04/25 Python
在Python中使用第三方模块的教程
2015/04/27 Python
python修改操作系统时间的方法
2015/05/18 Python
python深度优先搜索和广度优先搜索
2018/02/07 Python
python远程调用rpc模块xmlrpclib的方法
2019/01/11 Python
python面试题之列表声明实例分析
2019/07/08 Python
基于Python脚本实现邮件报警功能
2020/05/20 Python
基于python实现查询ip地址来源
2020/06/02 Python
Python3内置函数chr和ord实现进制转换
2020/06/05 Python
CSS3哪些新特性值得称赞
2016/03/02 HTML / CSS
经济管理专业毕业生自荐信范文
2014/01/02 职场文书
高一新生军训感言
2014/03/02 职场文书
奥巴马获胜演讲稿
2014/05/15 职场文书
本科毕业生应聘自荐信范文
2014/06/26 职场文书
镇政府副镇长群众路线专题民主生活会对照检查材料
2014/09/19 职场文书
贪污受贿检讨书范文
2014/11/19 职场文书
员工辞退通知书
2015/04/17 职场文书
2015个人年度工作总结范文
2015/05/28 职场文书
哪类餐饮行业,最适合在高校创业?
2019/08/19 职场文书