Home > Backend Development > PHP Tutorial > How to batch update multiple records in laravel

How to batch update multiple records in laravel

黄舟
Release: 2023-03-16 18:30:01
Original
2935 people have browsed it

Preface

I believe that children who are familiar with laravel know that laravel can insert multiple records in batches at one time, but it does not update multiple records conditionally at once. .

Do you envy thinkphp's saveAll, do you envy ci's update_batch, but why does such an elegant laravel not have a similar batch update method?

Experts Googled the folk

and found that someone had already written on stackoverflow (https://stackoverflow.com/questions/26133977/laravel-bulk-update) Okay, but it doesn't prevent sql injection.

This article has been adjusted in conjunction with laravel's Eloquent to effectively prevent sql injection.

Sample code


<?php
namespace App\Models;
use DB;
use Illuminate\Database\Eloquent\Model;
/**
 * 学生表模型
 */
class Students extends Model
{
 protected $table = &#39;students&#39;;
 //批量更新
 public function updateBatch($multipleData = [])
 {
  try {
   if (empty($multipleData)) {
    throw new \Exception("数据不能为空");
   }
   $tableName = DB::getTablePrefix() . $this->getTable(); // 表名
   $firstRow = current($multipleData);
   $updateColumn = array_keys($firstRow);
   // 默认以id为条件更新,如果没有ID则以第一个字段为条件
   $referenceColumn = isset($firstRow[&#39;id&#39;]) ? &#39;id&#39; : 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(&#39;, &#39;, $sets);
   $whereIn = collect($multipleData)->pluck($referenceColumn)->values()->all();
   $bindings = array_merge($bindings, $whereIn);
   $whereIn = rtrim(str_repeat(&#39;?,&#39;, count($whereIn)), &#39;,&#39;);
   $updateSql = rtrim($updateSql, ", ") . " WHERE `" . $referenceColumn . "` IN (" . $whereIn . ")";
   // 传入预处理sql语句和对应绑定数据
   return DB::update($updateSql, $bindings);
  } catch (\Exception $e) {
   return false;
  }
 }
}
Copy after login

You can make adjustments according to your own needs. The following is Usage example:


// 要批量更新的数组
$students = [
 [&#39;id&#39; => 1, &#39;name&#39; => &#39;张三&#39;, &#39;email&#39; => &#39;zhansan@qq.com&#39;],
 [&#39;id&#39; => 2, &#39;name&#39; => &#39;李四&#39;, &#39;email&#39; => &#39;lisi@qq.com&#39;],
];
// 批量更新
app(Students::class)->updateBatch($students);
Copy after login

The generated SQL statement is as follows:


UPDATE pre_students
SET NAME = CASE
WHEN id = 1 THEN
 &#39;张三&#39;
WHEN id = 2 THEN
 &#39;李四&#39;
ELSE
 NAME
END,
 email = CASE
WHEN id = 1 THEN
 &#39;zhansan@qq.com&#39;
WHEN id = 2 THEN
 &#39;lisi@qq.com&#39;
ELSE
 email
END
WHERE
 id IN (1, 2)
Copy after login

The above is the detailed content of How to batch update multiple records in laravel. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template