MySQL replace into
阿新 • • 發佈:2018-10-26
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