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行的。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章