mysql實現upsert

  • upsert(update or insert), 即更新或寫入。
  • MySQL中實現upsert操作方式:
    思路:通過判斷插入的記錄裏是否存在主鍵索引或唯一索引衝突,來決定是插入還是更新。當出現主鍵索引或唯一索引衝突時則進行update操作,否則進行insert操作。
    實現:使用 ON DUPLICATE KEY UPDATE

來看看下面具體實現過程。

一、準備數據表

CREATE TABLE `demo` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `a` tinyint(1) unsigned NOT NULL DEFAULT '0',
  `b` tinyint(1) unsigned NOT NULL DEFAULT '0',
  `c` tinyint(1) unsigned NOT NULL DEFAULT '0',
  `d` tinyint(1) unsigned NOT NULL DEFAULT '0',
  `e` tinyint(1) unsigned NOT NULL DEFAULT '0',
  `f` tinyint(1) unsigned NOT NULL DEFAULT '0',
  PRIMARY KEY (`id`),
  UNIQUE KEY `unq_a_b_c` (`a`,`b`,`c`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=latin1;

注意:表中存在兩處索引,id爲主鍵索引,a,b,c爲聯合唯一索引。

二、寫入初始數據

insert into test.demo(a,b,c,d,e,f) values(1,1,1,1,1,1);

此時存在由abc散列組成唯一索引數據:1,1,1。

三、進一步實現

insert into demo(a,b,c,d,e,f) values(1,1,1,2,2,2) ON DUPLICATE KEY UPDATE a=2,b=2,c=3,d=4,e=5,f=6;
因爲已經存在由abc三列組成唯一索引數據:1,1,1,本次又寫入demo(a,b,c,d,e,f) values(1,1,1,2,2,2),會造成唯一索引衝突。
因此,會觸發ON DUPLICATE KEY 後面的 UPDATE a=2,b=2,c=3,d=4,e=5,f=6操作。

至此,已經實現upsert功能。請記住 ON DUPLICATE KEY UPDATE的用法。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章