SQL Server 刪除重復記錄,只保留一條記錄


原文地址:http://blog.csdn.net/eriato/article/details/17417303

有張表格之前沒有設計關鍵字段的唯一約束,導致有時候執行插入操作時不小心執行了多次就出現了重復記錄,后面重新加入唯一約束,由於已經有了重復記錄,無法添加,需要先刪除重復記錄。

        看了網上的一些刪除重復記錄的方法(好像都是轉載於同一篇文章,至少看了十幾篇都是同樣的內容),其中一個鏈接:http://blog.csdn.net/anya/article/details/6407280

        自己現在是需要建立多字段唯一約束(非主鍵),用文中的方法是不行的,反正在SQL Server 2012中是無法通過的。改寫了下,如下:

1、查詢重復記錄:

SELECT * FROM dbo.Table T
WHERE EXISTS (SELECT 字段1, 字段2, 字段3 FROM dbo.TableSign WHERE 字段1= T.字段1 AND 字段2= T.字段2
AND 字段3 = T.字段3 GROUP BY 字段1, 字段2, 字段3 HAVING COUNT(*) > 1)
AND T.SelfID NOT IN (SELECT MIN(SelfID) FROM dbo.Table GROUP BY 字段1, 字段2, 字段3 HAVING COUNT(*) > 1)

--其中:字段1, 字段2, 字段3指需要建立唯一約束的三個字段,SelfID指表Table中的一個自增字段。

2、刪除重復記錄,只保留SelfID最小的記錄,也就是第一次插入的記錄:

DELETE FROM dbo.TableSign
WHERE SelfID IN

(SELECT SelfID FROM dbo.Table T

WHERE EXISTS (SELECT 字段1, 字段2, 字段3 FROM dbo.TableSign WHERE 字段1= T.字段1 AND 字段2= T.字段2
AND 字段3 = T.字段3 GROUP BY 字段1, 字段2, 字段3 HAVING COUNT(*) > 1)
AND T.SelfID NOT IN (SELECT MIN(SelfID) FROM dbo.Table GROUP BY 字段1, 字段2, 字段3 HAVING COUNT(*) > 1))

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM