隨筆 - 154  文章 - 60  trackbacks - 0
          <2007年11月>
          28293031123
          45678910
          11121314151617
          18192021222324
          2526272829301
          2345678

          聲明:

          該blog是為了收集資料,認(rèn)識朋友,學(xué)習(xí)、提高技術(shù),所以本blog的內(nèi)容除非聲明,否則一律為轉(zhuǎn)載!!

          感謝那些公開自己技術(shù)成果的高人們!!!

          支持開源,尊重他人的勞動(dòng)!!

          常用鏈接

          留言簿(3)

          隨筆分類(148)

          隨筆檔案(143)

          收藏夾(2)

          其他

          學(xué)習(xí)(技術(shù))

          觀察思考(非技術(shù))

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          開發(fā)人員的噩夢——?jiǎng)h除重復(fù)記錄

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

            在SQL Server中除了對擁有十幾條記錄的表進(jìn)行人工刪除外,實(shí)現(xiàn)刪除重復(fù)記錄一般都是寫一段代碼,用游標(biāo)的方法一行一行檢查,刪除重復(fù)的記錄。因?yàn)檫@種方法需要對整個(gè)表進(jìn)行遍歷,所以對于表中的記錄數(shù)不是很大的時(shí)候還是可行的,如果一張表的數(shù)據(jù)達(dá)到上百萬條,用游標(biāo)的方法來刪除簡直是個(gè)噩夢,因?yàn)樗鼤?huì)執(zhí)行相當(dāng)長的一段時(shí)間。

            四板斧——輕松消除重復(fù)記錄

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

          CREATE TABLE Products (
          ProductID int,
          ProductName nvarchar (40),
          Unit char(2),
          UnitPrice money
          )


            表中的數(shù)據(jù)如圖1:




          圖1

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

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

          CREATE TABLE Products_temp (
          ProductID int,
          ProductName nvarchar (40),
          Unit char(2),
          UnitPrice money
          )

            第二板斧——為該表加上索引,并使其忽略重復(fù)的值

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

            按照圖2中圈出來的地方設(shè)置索引選項(xiàng)。


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

          insert into Products_temp Select * from Products

            此時(shí)SQL Server會(huì)返回如下提示:

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

            已忽略重復(fù)的鍵。

            它表明在產(chǎn)品信息臨時(shí)表Products_temp中不會(huì)有重復(fù)的行出現(xiàn)。

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

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

          delete Products
          insert into Products select * from Products_temp
          drop table Products_temp

            這樣就完成了對表中重復(fù)記錄的刪除。無論表有多大,它的執(zhí)行速度都是相當(dāng)快的,而且因?yàn)閹缀醪挥脤懻Z句,所以它也是很安全的。

            小提示:上述方法中刪除重復(fù)記錄取決于創(chuàng)建唯一索引時(shí)選擇的字段,在實(shí)際的操作過程中讀者務(wù)必首先確認(rèn)創(chuàng)建的唯一索引字段是否正確,以免將有用的數(shù)據(jù)刪除。
          posted on 2007-11-02 15:22 lk 閱讀(329) 評論(1)  編輯  收藏 所屬分類: DB

          FeedBack:
          # re: 在SQL Server中快速刪除重復(fù)記錄 2007-11-05 09:49 CoderDream
          圖片還在你的電腦里,請先上傳,否則除了你自己,別人是看不到圖片的!  回復(fù)  更多評論
            
          主站蜘蛛池模板: 盐山县| 黄骅市| 谢通门县| 江津市| 博白县| 巩留县| 林周县| 伊宁县| 长宁县| 古蔺县| 崇仁县| 沭阳县| 北川| 紫金县| 山西省| 蓬安县| 孙吴县| 油尖旺区| 长寿区| 大石桥市| 南江县| 教育| 金寨县| 巴东县| 隆子县| 贺兰县| 右玉县| 滦南县| 泗洪县| 祁门县| 龙泉市| 无为县| 金溪县| 漠河县| 洮南市| 哈密市| 怀化市| 巴林右旗| 唐海县| 电白县| 蚌埠市|