Skip to content

Zeroplex 生活隨筆

軟體開發、伺服器和生活瑣事

小 縮小字型大小。 中 重設字型大小。 大 放大字型大小。

MySQL 中 UPSERT (update or insert) 的語法

Posted on 2021 年 5 月 24 日2021 年 5 月 24 日 By 日落 在〈MySQL 中 UPSERT (update or insert) 的語法〉中尚無留言

MySQL 中要使用 IF ... ELSE 挺麻煩的,如果要在 insert 失敗 (資料已存在) 以後改對資料做 update 的話,可以考慮使用 INSERT .... ON DUPLICATE KEY。

假設要在 user 的 table 中,新增 user_id 和 mail:

INSERT INTO `user` (
    `user_id`,
    `mail`
) VALUES (
    "zero",
    "zero@zeroplex.tw"
)

當 user_id 是 unique index 時,上面的語法會失敗:duplicated key。
這時可以使用 MySQL 中的 INSERT … ON DUPLICATE KEY 語法,來讓 MySQL 自動判斷要使用 INSERT 還是 UPDATE:

INSERT INTO `user` (
    `user_id`,
    `mail`
) VALUES (
    "zero",
    "zero@zeroplex.tw"
) ON DUPLICATE KEY UPDATE 
    `mail` = "zero@zeroplex.tw"

上述語法,會讓 MySQL 執行時,若發現 zero 這個使用者已經存在時,變自動去更新他的 mail。

Tags:MySQL

文章導覽

Previous Post: Puzzle Together – 電腦上的自訂拼圖遊戲
Next Post: DOOM CAPTCHA – 玩毀滅公爵才能過關的圖形驗證碼

發佈留言 取消回覆

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *


其他

關於我  (About me)

小額贊助

  文章 RSS Feed

  留言 RSS Feed

Apache AWS Bash C/C++ Docker FreeBSD GCP Git Google Java JavaScript Laravel Linux Microsoft MSSQL MySQL Nginx PHP PHPUnit PostgreSQL Python Qt Ubuntu Unix Vim Web Windows WordPress XD 作業系統 分享 好站推薦 專題 攝影 新奇搞笑 新聞 旅遊 生活雜記 程式設計 網路架站 網頁設計 資訊學習 資訊安全 遊戲 音樂


創用 CC 授權條款
本著作係採用創用 CC 姓名標示-相同方式分享 4.0 國際 授權條款授權.