MySQL insert or update

業(yè)務(wù)場景

  • 我們經(jīng)常會遇到類似的業(yè)務(wù)場景,插入一條數(shù)據(jù)如果他不存在則執(zhí)行 insert 克婶,當(dāng)這條記錄存在的時候情萤,我們?nèi)?update 他的一些屬性(或者什么都不做)。

解決方案:

  • 使用 ON DUPLICATE KEY UPDATE
    主鍵 或者 唯一約束 重復(fù)時晒哄,執(zhí)行更新操作。
  • 使用 REPLACE INTO
    主鍵 或者 唯一約束 重復(fù)時柒傻,先 delete 再 insert。

ON DUPLICATE KEY UPDATE

  • 創(chuàng)建表预侯,建立唯一約束雌桑,準(zhǔn)備一條數(shù)據(jù)
CREATE TABLE `stu_class_ref` (
  `id` varchar(30) NOT NULL,
  `stu_id` varchar(30) DEFAULT NULL,
  `class_id` varchar(30) DEFAULT NULL,
  `note` varchar(100) DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `stu_id` (`stu_id`,`class_id`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

INSERT INTO 
`test`.`stu_class_ref`(`id`, `stu_id`, `class_id`, `note`) 
VALUES ('001', 'zhangsan', 'yuwen', NULL);
準(zhǔn)備數(shù)據(jù)
  • 使用 ON DUPLICATE KEY UPDATE
INSERT INTO 
`test`.`stu_class_ref`(`id`, `stu_id`, `class_id`, `note`) 
VALUES (UUID_SHORT(), 'zhangsan', 'yuwen', '我喜歡語文:)')
ON DUPLICATE KEY UPDATE note = '我喜歡語文:)'
> Affected rows: 2
> 時間: 0.042s
  • Affected rows: 2,MySQL 檢查插入的行是否會產(chǎn)生重復(fù)鍵錯誤膏斤,如果會則執(zhí)行update
ON DUPLICATE KEY UPDATE
  • 如果想要引用 VALUES 中的值,參考如下
INSERT INTO 
`test`.`stu_class_ref`(`id`, `stu_id`, `class_id`, `note`) 
VALUES (UUID_SHORT(), 'zhangsan', 'yuwen', NULL)
ON DUPLICATE KEY UPDATE note = VALUES(class_id)
> Affected rows: 2
> 時間: 0.006s
ON DUPLICATE KEY UPDATE

REPLACE INTO

  • MySQL 中 還有一個黑科技語法 REPLACE INTO
REPLACE INTO `stu_class_ref`(`id`, `stu_id`, `class_id`, `note`) 
VALUES (UUID_SHORT(), 'zhangsan', 'yuwen', NULL)
> Affected rows: 2
> 時間: 0.004s
REPLACE INTO
  • REPLACE INTO 就比較簡單粗暴了邪驮,他會先執(zhí)行delete 操作莫辨,然后insert

ON DUPLICATE KEY UPDATE 與 REPLACE INTO

  • 再來創(chuàng)建一張表, 創(chuàng)建三個唯一約束, 插入三條數(shù)據(jù)
CREATE TABLE `interesting` (
  `id` varchar(30) NOT NULL,
  `uni_a` varchar(30) DEFAULT NULL,
  `uni_b` varchar(30) DEFAULT NULL,
  `uni_c` varchar(30) DEFAULT NULL,
  `version` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `uni_a` (`uni_a`) USING BTREE,
  UNIQUE KEY `uni_b` (`uni_b`) USING BTREE,
  UNIQUE KEY `uni_c` (`uni_c`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

INSERT INTO `test`.`interesting`(`id`, `uni_a`, `uni_b`, `uni_c`, `version`) 
VALUES ('1', 'a', 'a', 'a', NULL);
INSERT INTO `test`.`interesting`(`id`, `uni_a`, `uni_b`, `uni_c`, `version`) 
VALUES ('2', 'b', 'b', 'b', NULL);
INSERT INTO `test`.`interesting`(`id`, `uni_a`, `uni_b`, `uni_c`, `version`) 
VALUES ('3', 'c', 'c', 'c', NULL);
準(zhǔn)備數(shù)據(jù)
  1. 執(zhí)行 ON DUPLICATE KEY UPDATE
INSERT INTO `interesting`(`id`, `uni_a`, `uni_b`, `uni_c`, `version`) 
VALUES (UUID_SHORT(), 'a', 'b', 'c', NULL)
ON DUPLICATE KEY UPDATE version = 666
> Affected rows: 2
> 時間: 0.049s
ON DUPLICATE KEY UPDATE
  • Affected rows: 2 但是其實(shí)三條主鍵都有沖突了
  1. 再看一下 REPLACE INTO
REPLACE INTO `interesting`(`id`, `uni_a`, `uni_b`, `uni_c`, `version`) 
VALUES (UUID_SHORT(), 'a', 'b', 'c', NULL)
> Affected rows: 4
> 時間: 0.026s
REPLACE INTO
  • Affected rows: 4 REPLACE INTO 將三條有沖突的全部delete 然后 insert

總結(jié):

  • ON DUPLICATE KEY UPDATE 只會對所匹配的第一行進(jìn)行update,
  • REPLACE INTO 會對所有匹配行進(jìn)行delete, insert
  • 所以應(yīng)避免對有多個唯一索引的表使用
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市毅访,隨后出現(xiàn)的幾起案子沮榜,更是在濱河造成了極大的恐慌,老刑警劉巖喻粹,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件查乒,死亡現(xiàn)場離奇詭異,居然都是意外死亡藻肄,警方通過查閱死者的電腦和手機(jī)从撼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來雄妥,“玉大人,你說我怎么就攤上這事醋拧∪阜眩” “怎么了薄啥?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵铣口,是天一觀的道長。 經(jīng)常有香客問我,道長已艰,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任盒件,我火速辦了婚禮,結(jié)果婚禮上切心,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布毕骡。 她就那樣靜靜地躺著启昧,像睡著了一般。 火紅的嫁衣襯著肌膚如雪田炭。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天涵叮,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼购岗,長吁一口氣:“原來是場噩夢啊……” “哼髓梅!你這毒婦竟也來了搔扁?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎澎粟,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體次企,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡客燕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片器瘪。...
    茶點(diǎn)故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡继阻,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情梁只,我是刑警寧澤,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布麦撵,位于F島的核電站,受9級特大地震影響诗充,放射性物質(zhì)發(fā)生泄漏押袍。R本人自食惡果不足惜苗桂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一吱殉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧崇棠,春花似錦、人聲如沸澳淑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽成箫。三九已至蹬昌,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像阳惹,于是被迫代替她去往敵國和親谍失。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,440評論 2 348

推薦閱讀更多精彩內(nèi)容