1. 程式人生 > >MySQL replace into

MySQL replace into

mar mark test 這樣的 pri 新增 sql 如果 ins

  • replace into。
  • MySQL中實現replace into操作方式:
    思路:通過判斷插入的記錄裏是否存在主鍵索引或唯一索引沖突,來決定是插入還是更新。當出現主鍵索引或唯一索引沖突時則進行update操作,否則進行insert操作。
    實現:使用 replace into t(filedA, filedB...) values(value1, value2);

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

一、準備數據表

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,2,3,1,1,1);

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

三、進一步實現

replace into into demo(a,b,c,d,e,f) values(1,2,3,2,2,2);
因為已經存在由abc三列組成唯一索引數據:1,1,1,本次又寫入demo(a,b,c,d,e,f) values(1,1,1,2,2,2),會造成唯一索引沖突。
因此,會刪除掉原來記錄,新增一條記錄。

    replace into字段有primary key字段時,會更新本條記錄
    replace into字段沒有primark key字段,發生唯一索引沖突,會刪除原來的記錄,新增一條記錄

    在向表中插入數據的時候,經常遇到這樣的情況:
    1. 首先判斷數據是否存在
    2. 如果不存在,則插入
    3. 如果存在,則更新

MySQL replace into