在 MySQL 中,插入(insert)一条记录,经常需要检查这条记录是否已经存在,只有当记录不存在时才执行插入操作。
mysql在存在主键冲突或者唯一键冲突的情况下,根据插入策略不同,一般有以下四种避免方法。
1、insert ignore
2、replace into
3、insert on duplicate key update
4、insert into if exists
注意,除非表有一个PRIMARY KEY或UNIQUE索引,否则,使用以上四个语句没有意义,与使用单纯的INSERT INTO相同。
1、INSERT INTO IF EXISTS
MySQL的INSERT INTO IF EXISTS语句可以保证不重复插入,一般用户批量导入一些格式化好的数据。
INSERT INTO category(catname,cattype,cid,caturl,keywords)
SELECT '中国人', 2, 2031, 'china','中国人民' FROM DUAL
WHERE NOT EXISTS
(SELECT catname FROM category WHERE catname = '中国人');
其中DUAL是临时表,不需要物理创建,这么用即可。
INSERT INTO TABLE (field1, field2, fieldn) SELECT
'field1',
'field2',
'field