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

2021-04-14 22:52:02 字數 1420 閱讀 1927

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

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

四板斧——輕鬆消除重覆記錄

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

create table products (

productid int,

productname nvarchar (40),

unit char(2),

unitprice money

) 假設產品chang和tofu的記錄在產品資訊表中存在重複。現在要刪除這些重複的記錄,只保留其中的一條。步驟如下:

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

create table products_temp (

productid int,

productname nvarchar (40),

unit char(2),

unitprice money

)第二板斧——為該錶加上索引,並使其忽略重複的值

方法是在企業管理器中找到上面建立的臨時表products _temp,單擊滑鼠右鍵,選擇所有任務,選擇管理索引,選擇新建。然後設定索引選項。

第三板斧——拷貝產品資訊到臨時表

insert into products_temp select * from products

伺服器: 訊息 3604,級別 16,狀態 1,行 1

已忽略重複的鍵。

它表明在產品資訊臨時表products_temp中不會有重複的行出現。

第四板斧——將新的資料匯入原表

將原產品資訊表products清空,並將臨時表products_temp中資料匯入,最後刪除臨時表products_temp。

delete products

insert into products select * from products_temp

drop table products_temp

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

開發人員的開發效率

影響開發效率的因素,總結有五大方面 任務不明確 流程不順暢 需求變更多 責任心不夠 能力有瓶頸。針對這些因素,分別可以從以下五個方面來優化和改進。制定清晰的規範尤其是開發規範。無規矩不成方圓。營造良好的團隊文化氛圍,人性化的管理方式。愉悅狀態下的工作效率遠遠高於抑鬱狀態下的效率。定期舉行技術分享交流...

開發人員眼中的LINQ

開發人員眼中的linq 微軟講師 張義先 在今年的三月份 微軟發布了最新一代的開發平台 visual studio 2008.在visual studio 2008 中提供了太多的新功能與新特性 這些新功能與新特性都極大地提高了開發人員的效率.提到 visual studio 2008 的新特性就不...

開發人員的方向選擇

面對日益豐富繁榮的軟體市場,不管是對於專業開發人員還是剛涉足程式設計的愛好人員來說,如何選擇技術 事業上的發展方向,實在是乙個值得慎重考慮的問題。以下是我根據個人的從業感受結合本人對軟體發展趨勢的猜測所作的一些建議性歸納,希望對讀者 同仁 們有乙個好的參考 想要擺脫來自行業權威層的商業競爭給開發者們...