熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> SQL Server >> 正文

在SQL Server中快速刪除重復記錄

2013-11-15 14:47:29  來源: SQL Server 

  開發人員的噩夢——刪除重復記錄
  想必每一位開發人員都有過類似的經歷在對數據庫進行查詢或統計的時候不時地會碰到由於表中存在重復的記錄而導致查詢和統計結果不准確解決該問題的辦法就是將這些重復的記錄刪除只保留其中的一條
  在SQL Server中除了對擁有十幾條記錄的表進行人工刪除外實現刪除重復記錄一般都是寫一段代碼用游標的方法一行一行檢查刪除重復的記錄因為這種方法需要對整個表進行遍歷所以對於表中的記錄數不是很大的時候還是可行的如果一張表的數據達到上百萬條用游標的方法來刪除簡直是個噩夢因為它會執行相當長的一段時間
  四板斧——輕松消除重復記錄
  殊不知在SQL Server中有一種更為簡單的方法它不需要用游標只要寫一句簡單插入語句就能實現刪除重復記錄的功能為了能清楚地表述我們首先假設存在一個產品信息表Products其表結構如下 CREATE TABLE Products (
ProductID int
ProductName nvarchar ()
Unit char()
UnitPrice money
)

 
 
  產品Chang和Tofu的記錄在產品信息表中存在重復現在要刪除這些重復的記錄只保留其中的一條步驟如下
  第一板斧——建立一張具有相同結構的臨時表
CREATE TABLE Products_temp (
ProductID int
ProductName nvarchar ()
Unit char()
UnitPrice money
)

 
  第二板斧——為該表加上索引並使其忽略重復的值
  方法是在企業管理器中找到上面建立的臨時表Products _temp單擊鼠標右鍵選擇所有任務選擇管理索引選擇新建一個索引然後選擇“唯一值”選擇“忽略重復值”

  第三板斧——拷貝產品信息到臨時表
insert into Products_temp Select * from Products
 
  此時SQL Server會返回如下提示
  服務器: 消息 級別 狀態
  已忽略重復的鍵
  它表明在產品信息臨時表Products_temp中不會有重復的行出現
  第四板斧——將新的數據導入原表
  將原產品信息表Products清空並將臨時表Products_temp中數據導入最後刪除臨時表Products_temp
delete Products
insert into Products select * from Products_temp
drop table Products_temp

 
  這樣就完成了對表中重復記錄的刪除無論表有多大它的執行速度都是相當快的而且因為幾乎不用寫語句所以它也是很安全的
  小提示上述方法中刪除重復記錄取決於創建唯一索引時選擇的字段在實際的操作過程中讀者務必首先確認創建的唯一索引字段是否正確以免將有用的數據刪除



From:http://tw.wingwit.com/Article/program/SQLServer/201311/22325.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.