Laravel 批量更新多条数据的示例
2017-11-27 09:24
811 查看
引言
最近在写任务中,碰到一个问题,需要批量更新多条数据,但是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框架 Laravel Eloquent ORM 批量插入数据 && 批量更新目前没有
- Ado.net批量添加和更新数据简单示例
- Ado.net批量添加和更新数据简单示例
- laravel实现批量更新多条记录的方法示例
- SSH笔记-类型转换器和错误信息显示、复杂属性、批量更新模型数据
- 批量导入-更新 数据的几种方法
- PHP中批量更新数据表中多条记录
- C#中DataGridView的数据批量更新
- Yii2 购物车 批量插入,更新数据
- flex图表数据动态更新效果示例
- GridView如何更新批量数据和单条记录(downmoon)?
- MySQL 批量更新数据
- hibernate批量删除和更新数据
- mysql 根据select内容批量更新数据
- ibatis 的批量插入 批量更新数据
- php+mysqli实现批量执行插入、更新及删除数据的方法
- laravel框架即点击改,批量删除,更新日志
- Mysql 一条SQL语句实现批量更新数据,update结合case、when和then的使用案例
- 关于Dataset批量更新数据的实例方法
- 关于客户主数据的批量更新