首頁 > 資料庫 > mysql教程 > MySQL的ON DUPLICATE KEY UPDATE如何有效率地處理批次插入和更新?

MySQL的ON DUPLICATE KEY UPDATE如何有效率地處理批次插入和更新?

Susan Sarandon
發布: 2025-01-11 10:31:42
原創
315 人瀏覽過

How Can MySQL's ON DUPLICATE KEY UPDATE Handle Bulk Inserts and Updates Efficiently?

使用 ON DUPLICATE KEY UPDATE 優化 MySQL 中的批次插入和更新

在批次插入 MySQL 表期間管理唯一值可能很複雜。 ON DUPLICATE KEY UPDATE 子句提供了一個有效的解決方案,可以根據唯一鍵約束同時插入新行和更新現有行。

本指南示範如何在表格(例如「beautiful」)中插入或更新資料列,其中「name」列充當唯一鍵。 提出了兩種方法:

對於 MySQL 8.0.19 及更高版本:

利用行別名進行簡潔更新:

<code class="language-sql">INSERT INTO beautiful (name, age)
VALUES
('Helen', 24),
('Katrina', 21),
('Samia', 22),
('Hui Ling', 25),
('Yumie', 29)
AS new
ON DUPLICATE KEY UPDATE
    age = new.age
    -- ... other columns to update ...</code>
登入後複製

對於 8.0.19 之前的 MySQL 版本:

使用 VALUES 關鍵字引用插入的值:

<code class="language-sql">INSERT INTO beautiful (name, age)
VALUES
('Helen', 24),
('Katrina', 21),
('Samia', 22),
('Hui Ling', 25),
('Yumie', 29)
ON DUPLICATE KEY UPDATE
    age = VALUES(age),
    -- ... other columns to update ...</code>
登入後複製

在這兩種方法中,ON DUPLICATE KEY UPDATE 指定在偵測到重複的唯一鍵時要修改哪些列。這確保了資料完整性,同時在單一操作中有效處理插入​​和更新。

以上是MySQL的ON DUPLICATE KEY UPDATE如何有效率地處理批次插入和更新?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板