SQL 重复数据插入

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL 重复数据插入相关的知识,希望对你有一定的参考价值。

参考技术A 使用NOT EXISTS:

INSERT INTO TABLE_2
(id, name)
SELECT t1.id,
t1.name
FROM TABLE_1 t1
WHERE NOT EXISTS(SELECT id
FROM TABLE_2 t2
WHERE t2.id = t1.id)
使用NOT IN:

INSERT INTO TABLE_2
(id, name)
SELECT t1.id,
t1.name
FROM TABLE_1 t1
WHERE t1.id NOT IN (SELECT id
FROM TABLE_2)
使用LEFT JOIN/IS NULL:

INSERT INTO TABLE_2
(id, name)
SELECT t1.id,
t1.name
FROM TABLE_1 t1
LEFT JOIN TABLE_2 t2 ON t2.id = t1.id
WHERE t2.id IS NULL

SQL多个主键的表,插入数据有重复时,查询数据的重复值?


SQL多个主键的表,插入数据有重复时,会提示违反主键约束不能插入的错误。那么,如何找到插入数据的重复值?



解决方法:使用group by

 

假设有个表#a,有saleid,vendorid,comid,price,saleprice,quantity等字段。

主键是:saleid,vendorid,comid三个。假设插入#a的数据源可能会有重复的。

即:saleid,vendorid,comid三个字段都一样的字段,那么插入#a的时候会报主键冲突,违反主键约束。

 

如果想找出#a表中插入重复的值可用下面语句来查询:

Select saleid,vendorid,comid,count(*) from #a group by saleid,vendorid,comid having count(*)>1

以上语句会按照三个主键saleid,vendorid,comid分组,如果saleid,vendorid,comid都一样的记录则统计相同的有几行记录。Group by 后面的having条件则是查询出相同记录大于1行的。


本文出自 “远方_chen” 博客,请务必保留此出处http://chenshirong.blog.51cto.com/3945427/1884101

以上是关于SQL 重复数据插入的主要内容,如果未能解决你的问题,请参考以下文章

向oracle数据库中插入数据时,先判断插入数据是不是重复,如果重复,通过sql提示重新输入,否则直接插入

SQL 重复数据插入

将字符串'india's'插入sql数据库[重复]

SQL执行插入时,遇到重复键值时,如何设置才能让新插入的数据覆盖原有旧数据;要用存储过程么?

将数据插入oracle sql live [重复]

撇号未插入 SQL 数据库 [重复]