当前位置: 首页 > news >正文

laravel框架中批量更新数据

在php框架中 tp中就有批量更新封装好的 SaveAll

在laravel中有批量插入没有批量更新操作;因此我们可以自己去封装一个 然后批量进行更新操作

封装参考代码:

/*** 批量更新** @param $tableName 表名称* @param string $pk 更新的字段* @param array $multipleData 要更新的数据* @return bool|int*/
public function updateBatch($tableName, string $pk = 'id', array $multipleData = []): bool|int
{try {if (empty($multipleData)) {Log::info("批量更新数据为空");return false;}$firstRow = current($multipleData);$updateColumn = array_keys($firstRow);// 默认以id为条件更新,如果没有ID则以第一个字段为条件$referenceColumn = !isset($firstRow[$pk]) ? 'id' : current($updateColumn);unset($updateColumn[0]);// 拼接sql语句$updateSql = "UPDATE " . $tableName . " SET ";$sets = [];$bindings = [];foreach ($updateColumn as $uColumn) {$setSql = "`" . $uColumn . "` = CASE ";foreach ($multipleData as $data) {$setSql .= "WHEN `" . $referenceColumn . "` = ? THEN ? ";$bindings[] = $data[$referenceColumn];$bindings[] = $data[$uColumn];}$setSql .= "ELSE `" . $uColumn . "` END ";$sets[] = $setSql;}$updateSql .= implode(', ', $sets);$whereIn = collect($multipleData)->pluck($referenceColumn)->values()->all();$bindings = array_merge($bindings, $whereIn);$whereIn = rtrim(str_repeat('?,', count($whereIn)), ',');$updateSql = rtrim($updateSql, ", ") . " WHERE `" . $referenceColumn . "` IN (" . $whereIn . ")";Log::info($updateSql);// 传入预处理sql语句和对应绑定数据return DB::update($updateSql, $bindings);} catch (\Exception $e) {Log::info("批量更新数据失败:" . $e->getMessage());return false;}
}

 运行前可以先 打印查看数据是否正确 这个封装可以有效防止sql注入问题

一般用于脚本批量更新

下标是表名称 --我是多表更新 

 单表这种格式就行

 

 

http://www.lryc.cn/news/128783.html

相关文章:

  • 【Linux】POSIX信号量和基于环形队列的生产消费者模型
  • Rust之编写自动化测试
  • 【网络】网络层——IP协议
  • 动力电池系统介绍(十三)——高压互锁(HVIL)
  • C# 一种求平方根的方法 立方根也可以 极大 极小都可以
  • 爬虫逆向实战(十二)--某交易所登录
  • 【C++入门到精通】C++入门 —— list (STL)
  • SOLIDWORKS有限元分析
  • Kotlin Flow 冷流
  • Android Socket使用TCP协议实现手机投屏
  • 【云原生,k8s】Helm应用包管理器介绍
  • 两个内网之间的linux服务器如何互相登录?快解析内网穿透
  • sql server 存储过程 set ansi_nulls set quoted_identifier,out 、output
  • 1046:判断一个数能否同时被3和5整除
  • 优漫动游零基础如何学习好UI设计
  • Android岗位技能实训室建设方案
  • Mysql系列:Mysql5.7编译安装--系统环境:Centos7 / CentOS9 Stream
  • Docker容器与虚拟化技术:Dockerfile部署LNMP
  • elementUI date-picker 日期格式转为 2023/08/08格式
  • 生成式 AI 在泛娱乐行业的应用场景实践 – 助力风格化视频内容创作
  • elementPlus——图标引入+批量注册全局组件——基础积累
  • 国标GB28181安防视频平台EasyGBS显示状态正常,却无法播放该如何解决?
  • TIOVX:opencv的Mat类图像零拷贝转为openvx的vx_image格式,通过Not节点无效果问题记录
  • 变压器故障诊断(python代码,逻辑回归/SVM/KNN三种方法同时使用,有详细中文注释)
  • ASEMI探索整流桥GBU814的独特优势和应用领域
  • js脚本自动化之葫芦娃
  • 从零基础到精通IT:探索高效学习路径与成功案例
  • 2023.8.8巨人网络数据开发工程师面试复盘
  • Python Opencv实践 - 图像仿射变换
  • 如何使用CSS实现一个模态框(Modal)效果?