sqlserver中删除重复行的方法
前段時間,公司同事不小心在數據庫表中重加了數據,不多,7000條左右。因為信息比較重要,不能刪錯了。但也不能有重復數據。所以找我求救。
解決問題后,總結如下:
SQL Server刪除重復行是我們最常見的操作之一,下面就為您介紹六種適合不同情況的SQL Server刪除重復行的方法,供您參考。
1.如果有ID字段,就是具有唯一性的字段?
delect?? table?? where?? id?? not?? in?? (?????
?
select?? max(id)?? from?? table?? group?? by?? col1,col2,col3...?????
)?????
group?? by?? 子句后跟的字段就是你用來判斷重復的條件,如只有col1,那么只要col1字段內容相同即表示記錄相同。?
2. 如果是判斷所有字段也可以這樣?
select?? *?? into?? #aa?? from?? table?? group?? by?? id1,id2,....?????
delete?? table???????
insert?? into?? table???????
select?? *?? from?? #aa????
3. 沒有ID的情況?
select?? identity(int,1,1)?? as?? id,*?? into?? #temp?? from?? tabel?????
delect?? #?? where?? id?? not?? in?? (?????
select?? max(id)?? from?? #?? group?? by?? col1,col2,col3...)?????
delect?? table?????
inset?? into?? table(...)?????
select?? .....?? from?? #temp????
4. col1+','+col2+','...col5 聯合主鍵?
select?? *?? from???? table?? where?? col1+','+col2+','...col5?? in?? (?????
select?? max(col1+','+col2+','...col5)?? from?? table???????
where?? having?? count(*)>1?????
group?? by?? col1,col2,col3,col4???????
)????
group?? by?? 子句后跟的字段就是你用來判斷重復的條件,如只有col1,那么只要col1字段內容相同即表示記錄相同。?
5.
select?? identity(int,1,1)?? as?? id,*?? into?? #temp?? from?? tabel?????
select?? *?? from???? #temp?? where?? id?? in?? (?????
select?? max(id)?? from?? #emp?? where?? having?? count(*)>1?? group?? by?? col1,col2,col3...)????
6.
select?? distinct?? *?? into?? #temp?? from?? tablename???????
delete?? tablename???????
go?????
insert?? tablename?? select?? *?? from?? #temp?? Sqlclub???
go?????
drop?? table?? #temp??
以上就是SQL Server刪除重復行的方法介紹。
?
總結
以上是生活随笔為你收集整理的sqlserver中删除重复行的方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: dabeicun 2013源码下载
- 下一篇: 飞鸽传书人必须对自己守信