1. ON DUPLICATE
使用ON DUPLICATE插入的字段中必须有唯一约束,否则会出现重复值
INSERT INTO table
(name, gender, age)
VALUES
('Jerry', 'boy', 9)
ON DUPLICATE KEY UPDATE name='Jerry',gender='girl', age=10;
目前表中没有唯一约束,执行两遍插入语句,会出现两个重复数据,id为49的Jerry和id为50的Jerry,并没有达到修改的目的,将name字段增加唯一约束
ALTER TABLE `table` ADD unique(`name`);
表中已经存在名为Jerry的数据,再次插入时更新为 Jerry,girl, 10
2. REPLACE
replace into 跟 insert 功能类似,不同点在于:replace into 首先尝试插入数据到表中, 1. 如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。 2. 否则,直接插入新数据。
要注意的是:插入数据的表必须有主键或者是唯一索引!否则的话,replace into 会直接插入数据,这将导致表中出现重复的数据。
REPLACE INTO table(name, gender, age) VALUES ('Jerry', 'girl', 10);
或
REPLACE INTO table(name, gender, age) SELECT 'Jerry', 'girl', 10;
或
REPLACE INTO test SET name='Jerry', gender='girl', age=10;