国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

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

2024-08-31 00:48:05
字體:
供稿:網(wǎng)友
  開發(fā)人員的噩夢——刪除重復記錄

  想必每一位開發(fā)人員都有過類似的經(jīng)歷,在對數(shù)據(jù)庫進行查詢或統(tǒng)計的時候不時地會碰到由于表中存在重復的記錄而導致查詢和統(tǒng)計結(jié)果不準確。解決該問題的辦法就是將這些重復的記錄刪除,只保留其中的一條。

  在sql server中除了對擁有十幾條記錄的表進行人工刪除外,實現(xiàn)刪除重復記錄一般都是寫一段代碼,用游標的方法一行一行檢查,刪除重復的記錄。因為這種方法需要對整個表進行遍歷,所以對于表中的記錄數(shù)不是很大的時候還是可行的,如果一張表的數(shù)據(jù)達到上百萬條,用游標的方法來刪除簡直是個噩夢,因為它會執(zhí)行相當長的一段時間。

  四板斧——輕松消除重復記錄

  殊不知在sql server中有一種更為簡單的方法,它不需要用游標,只要寫一句簡單插入語句就能實現(xiàn)刪除重復記錄的功能。為了能清楚地表述,我們首先假設存在一個產(chǎn)品信息表products,其表結(jié)構如下:

create table products (
productid int,
productname nvarchar (40),
unit char(2),
unitprice money
)
  表中的數(shù)據(jù)如圖1:


  圖1中可以看出,產(chǎn)品chang和tofu的記錄在產(chǎn)品信息表中存在重復。現(xiàn)在要刪除這些重復的記錄,只保留其中的一條。步驟如下:

  第一板斧——建立一張具有相同結(jié)構的臨時表

create table products_temp (
productid int,
productname nvarchar (40),
unit char(2),
unitprice money
)
  第二板斧——為該表加上索引,并使其忽略重復的值

  方法是在企業(yè)管理器中找到上面建立的臨時表products _temp,單擊鼠標右鍵,選擇所有任務,選擇管理索引,選擇新建。如圖2所示。

  按照圖2中圈出來的地方設置索引選項。


  第三板斧——拷貝產(chǎn)品信息到臨時表

insert into products_temp select * from products
  此時sql server會返回如下提示:

  服務器: 消息 3604,級別 16,狀態(tài) 1,行 1

  已忽略重復的鍵。

  它表明在產(chǎn)品信息臨時表products_temp中不會有重復的行出現(xiàn)。

  第四板斧——將新的數(shù)據(jù)導入原表

  將原產(chǎn)品信息表products清空,并將臨時表products_temp中數(shù)據(jù)導入,最后刪除臨時表products_temp。

delete products
insert into products select * from products_temp
drop table products_temp
  這樣就完成了對表中重復記錄的刪除。無論表有多大,它的執(zhí)行速度都是相當快的,而且因為幾乎不用寫語句,所以它也是很安全的。

  小提示:上述方法中刪除重復記錄取決于創(chuàng)建唯一索引時選擇的字段,在實際的操作過程中讀者務必首先確認創(chuàng)建的唯一索引字段是否正確,以免將有用的數(shù)據(jù)刪除。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 波密县| 溆浦县| 禹州市| 惠来县| 综艺| 偏关县| 沙河市| 灵石县| 阳山县| 大埔区| 禄丰县| 闽清县| 库伦旗| 富源县| 姚安县| 上虞市| 高雄县| 西畴县| 湖北省| 利辛县| 德安县| 漳州市| 托里县| 汝南县| 荣成市| 武定县| 鹤庆县| 蓝山县| 沙雅县| 彝良县| 尼玛县| 织金县| 双峰县| 宁河县| 岗巴县| 德州市| 宝兴县| 临猗县| 乾安县| 上蔡县| 汶川县|