您好,登錄后才能下訂單哦!
使用Laravel怎么批量更新多條數據?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
mysql case…when的用法
MySQL 的 case when 的語法有兩種:
簡單函數
CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END
CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END: 枚舉這個字段所有可能的值
select id,status '狀態值', case status when 10 then '未開始' when 20 then '配送中' when 30 then '已完成' when 40 then '已取消' End '狀態' from table
輸出結果:
搜索函數
CASE WHEN [expr] THEN [result1]…ELSE [default] END
CASE WHEN [expr] THEN [result1]…ELSE [default] END:搜索函數可以寫判斷,并且搜索函數只會返回第一個符合條件的值,其他case被忽略
select id,lessee_id '租戶ID', case when lessee_id <=1 then '自用系統' when lessee_id >1 then '租用系統' End '系統分類' from waybill_base_info
case…when實現數據庫的批量更新
更新單列的值
UPDATE base_info SET city_id = CASE id WHEN 1 THEN WHEN 2 THEN WHEN 3 THEN END WHERE id IN (1,2,3)
這句sql的意思是,更新city_id 字段:
如果id=1 則city_id 的值為100010,
如果id=2 則 city_id 的值為100011,
如果id=3 則 city_id 的值為100012。
即是將條件語句寫在了一起。
這里的where部分不影響代碼的執行,但是會提高sql執行的效率。
確保sql語句僅執行需要修改的行數,這里只有3條數據進行更新,而where子句確保只有3行數據執行。
UPDATE base_info SET city_id = CASE id WHEN 1 THEN 100010 WHEN 2 THEN 100011 WHEN 3 THEN 100012 END, city_name = CASE id WHEN 1 THEN ‘北京' WHEN 2 THEN ‘上海' WHEN 3 THEN ‘廣州' END WHERE id IN (1,2,3)
不過這個有個缺點 : 要注意的問題是SQL語句的長度,需要考慮程序運行環境所支持的字符串長度,當然這也可以更新mysql的設置來擴展。
在model方法中封裝該批量更新的方法:
//批量更新 public function updateBatch($multipleData = []) { try { if (empty($multipleData)) { Log::info("批量更新數據為空"); return false; } $tableName = $this->table; // 表名 $firstRow = current($multipleData); $updateColumn = array_keys($firstRow); // 默認以id為條件更新,如果沒有ID則以第一個字段為條件 $referenceColumn = isset($firstRow['id']) ? '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) { return false; } }
在service層拼接需要更新的數據,并調用該函數:
foreach ($taskInfo as $info) { $cityId = $info['requirement']['city_ids']; //此處省略n行代碼 $cityInfo = ['id' => $dataId[$info['id']]['id'], 'city_id' => $cityId]; if ($cityInfo) { $cityInfos[] = $cityInfo; } } $res = $this->waybillDriverInfoModel->updateBatch($cityInfos); }
拼接的批量更新的數組格式為:
$students = [
[‘id' => 1, ‘city_id' => ‘100010'],
[‘id' => 2, ‘city_id' => ‘100011'],
];
生成的SQL語句如下:
UPDATE base_info SET `city_id` = CASE WHEN `id` = 1 THEN 100010 WHEN `id` = 2 THEN 100011 ELSE `city_id` END WHERE `id` IN (1,2)
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。