背景
在阅读 MySQL 批量插入,如何不插入重复数据? 时顺便整理出 Sql server和Oracle的方案。
文章内容以 MySQL 批量插入,如何不插入重复数据? 为主,同时补充 sql server和oracle的替代方案。
1、insert ignore into
当插入数据时,如出现错误时,如重复数据,将不返回错误,只以警告形式返回。所以使用ignore请确保语句本身没有问题,否则也会被忽略掉。例如:
INSERT IGNORE INTO user (field) VALUES ('xxx')
注意 ignore 有其他副作用,请查看 ignore 的具体含义。
支持的数据库:
- MySQL
替代方法:
- sql server : 使用 if exist()
- oracle : 参考stackoverflow上讨论
2、on duplicate key update
当primary或者unique重复时,则执行update语句,如update后为无用语句,如id=id,则同1功能相同,但错误不会被忽略掉。
例如,为了实现name重复的数据插入不报错,可使用一下语句:
INSERT INTO user (field) VALUES ('xxx') ON duplicate KEY UPDATE id = id
这种方法有个前提条件,就是,需要插入的约束,需要是主键或者唯一约束(在你的业务中那个要作为唯一的判断就将那个字段设置为唯一约束也就是unique key)。
支持的数据库:
- MySQL
其他数据库替代方法:
3、insert … select … where not exist
根据select的条件判断是否插入,可以不光通过primary 和unique来判断,也可通过其它条件。例如:
INSERT INTO user (field) SELECT 'xxx' FROM dual WHERE NOT EXISTS (SELECT id FROM user WHERE id = 1)
这种方法其实就是使用了mysql的一个临时表的方式,但是里面使用到了子查询,效率也会有一点点影响,如果能使用上面的就不使用这个。
支持的数据库:
- MySQL
- Sql server
- Oracle
4、replace into
如果存在primary or unique相同的记录,则先删除掉。再插入新记录。
REPLACE INTO user SELECT 1, 'telami' FROM books
这种方法就是不管原来有没有相同的记录,都会先删除掉然后再插入。
支持的数据库:
- MySQL
替代方法: