SQL Server刪除重復行的6個方法


SQL Server刪除重復行是我們最常見的操作之一,下面就為您介紹六種適合不同情況的SQL Server刪除重復行的方法,供您參考。

1.如果有ID字段,就是具有唯一性的字段  

delect   table  tableName  where   id   not   in   (   select   max(id)   from   table   group   by   col1,col2,col3...   )     

group   by   子句后跟的字段就是你用來判斷重復的條件,如只有col1,那么只要col1字段內容相同即表示記錄相同。  

2. 如果是判斷所有字段也可以這樣  ,【對於表中的指定的字段的進行檢查是否相同】

select   *   into   #temp  from   tablename    group   by   id1,id2,....     

delete    tablename       

insert   into   table  select   *   from   #temp  

drop   table   #temp  

3.  首先去重復,再獲取N*1條數據插入到臨時表中,【對於表中的所有字段的進行檢查是否相同】,再將原表的數據刪除,然后將臨時表的數據插入到原表,最后刪除臨時表。

select   distinct   *   into   #temp   from   tablename       

delete       tablename       

go     

insert   tablename   select   *   from   #temp     

go     

drop   table   #temp  

  

4. 沒有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    

5. 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字段內容相同即表示記錄相同。  

6. 

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...)    


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM