龙空技术网

MySQL数据存在就更新,不存在就添加

架构师聊技术 370

前言:

而今各位老铁们对“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表存在