1. 程式人生 > >SQL Server 刪除重複記錄,只保留一條記錄

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

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

        看了網上的一些刪除重複記錄的方法(好像都是轉載於同一篇文章,至少看了十幾篇都是同樣的內容),其中一個連結: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))