<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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

    聲明:

    該blog是為了收集資料,認識朋友,學習、提高技術,所以本blog的內容除非聲明,否則一律為轉載!!

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

    支持開源,尊重他人的勞動!!

    常用鏈接

    留言簿(3)

    隨筆分類(148)

    隨筆檔案(143)

    收藏夾(2)

    其他

    學習(技術)

    觀察思考(非技術)

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    開發人員的噩夢——刪除重復記錄

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

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

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

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

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


      表中的數據如圖1:




    圖1

      圖1中可以看出,產品Chang和Tofu的記錄在產品信息表中存在重復。現在要刪除這些重復的記錄,只保留其中的一條。步驟如下:

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

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

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

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

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


      第三板斧——拷貝產品信息到臨時表

    insert into Products_temp Select * from Products

      此時SQL Server會返回如下提示:

      服務器: 消息 3604,級別 16,狀態 1,行 1

      已忽略重復的鍵。

      它表明在產品信息臨時表Products_temp中不會有重復的行出現。

      第四板斧——將新的數據導入原表

      將原產品信息表Products清空,并將臨時表Products_temp中數據導入,最后刪除臨時表Products_temp。

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

      這樣就完成了對表中重復記錄的刪除。無論表有多大,它的執行速度都是相當快的,而且因為幾乎不用寫語句,所以它也是很安全的。

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

    FeedBack:
    # re: 在SQL Server中快速刪除重復記錄 2007-11-05 09:49 CoderDream
    圖片還在你的電腦里,請先上傳,否則除了你自己,別人是看不到圖片的!  回復  更多評論
      
    主站蜘蛛池模板: 午夜不卡AV免费| 人妻丰满熟妇无码区免费| 亚洲人成影院在线无码按摩店| 全免费a级毛片免费看| 亚洲国产熟亚洲女视频| 亚洲精品无码久久不卡| 免费人妻无码不卡中文字幕系| 亚洲精品无码高潮喷水A片软| 国产亚洲精品激情都市| 免费大片黄在线观看yw| fc2成年免费共享视频网站| 亚洲一区二区三区四区视频| 亚洲精品国产高清嫩草影院 | 日韩免费a级毛片无码a∨| 日韩成人精品日本亚洲| 91亚洲精品视频| 亚洲精品国产高清嫩草影院| 黄网站色在线视频免费观看| 一级**爱片免费视频| 亚洲综合欧美色五月俺也去| 亚洲精品中文字幕乱码三区| 思思99re66在线精品免费观看| 国产免费无码一区二区| 国产综合成人亚洲区| 亚洲精品在线播放| 亚洲中文字幕无码爆乳AV| 成人毛片18女人毛片免费96| 免费成人高清在线视频| 国产成人精品亚洲| 亚洲H在线播放在线观看H| 亚洲精品无码专区久久同性男| 丁香花在线观看免费观看| 一级毛片免费毛片一级毛片免费 | 97亚洲熟妇自偷自拍另类图片| 亚洲国产精品一区二区九九| 亚洲第一成年免费网站| 日韩人妻无码精品久久免费一| eeuss影院免费92242部| 日本亚洲高清乱码中文在线观看| 亚洲三级在线免费观看| 久久精品国产精品亚洲艾|