本文主要是介绍MySQL唯一性插入数据的几种实现实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在 MySQL 中,插入(insert)一条记录,经常需要检查这条记录是否已经存在,只有当记录不存在时才执行插入操作。
mysql在存在主键冲突或者唯一键冲突的情况下,根据插入策略不同,一般有以下四种避免方法。
1、insert ignore2、replace into3、insert on duplicate key update4、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
这篇关于MySQL唯一性插入数据的几种实现实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!