前言:
而今各位老铁们对“mysql表存在”都比较珍视,各位老铁们都需要剖析一些“mysql表存在”的相关资讯。那么小编也在网摘上网罗了一些关于“mysql表存在””的相关资讯,希望咱们能喜欢,你们快快来了解一下吧!做业务系统,经常遇到初始化一些数据,但如果每次都检查就比较麻烦,下面的方法可以解决类似的问题。
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;
文章来源:
版权声明:
本站文章均来自互联网搜集,如有侵犯您的权益,请联系我们删除,谢谢。
标签: #mysql表存在