博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server删除重复行的6个方法
阅读量:6950 次
发布时间:2019-06-27

本文共 1229 字,大约阅读时间需要 4 分钟。

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

转载地址:http://sdkil.baihongyu.com/

你可能感兴趣的文章
iOS 获取本地视频的缩略图
查看>>
poj 2485 Highways
查看>>
前端路由的简单使用
查看>>
OD使用教程4 - 调试篇04|解密系列
查看>>
浏览器缓存
查看>>
css中的一些兼容问题
查看>>
mysql 架构 ~ 异地多活
查看>>
纯css实现全兼容的元素水平垂直居中
查看>>
GBDT算法简述
查看>>
redis缓存架构-01-缓存架构方案
查看>>
goroutine
查看>>
[洛谷1231]教辅的组成
查看>>
在aspx页面中使用三元表达式
查看>>
iOS定位和位置信息获取
查看>>
Debian 7 安装Firefox
查看>>
ajax模式 同步和异步
查看>>
我喜欢的vs code快捷键for mac
查看>>
sql表的复制问题
查看>>
es6的新内容
查看>>
Java教程
查看>>