码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2016-12-20 07:50:58      阅读:229      评论:0      收藏:0      [点我收藏+]

标签:sql group by 主键重复


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多个主键的表,插入数据有重复时,查询数据的重复值?

标签:sql group by 主键重复

原文地址:http://chenshirong.blog.51cto.com/3945427/1884101

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!