分析SQL Server删除重复行的6个方法
发布时间:2021-12-24 12:11:10  所属栏目:MsSql教程  来源:互联网 
            导读:1.如果有ID字段,就是具有唯一性的字段 复制代码 代码如下: delect table where id not in ( select max(id) from table group by col1,col2,col3... ) group by 子句后跟的字段就是你用来判断重复的条件,如只有col1,那么只要col1字段内容相同即表示记录
                
                
                
            | 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删除重复行的方法介绍。 (编辑:银川站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! | 
相关内容
- sql-server – 使用带有nHibernate的CreateSQLQuery的SQL S
- ssis延迟验证方法是什么?一文带你看懂
- sql-server – 如何将SQL Server死锁报告中的密钥转换为值?
- sql-server – 在SAN环境中对SQL索引进行碎片整理是否有任何
- sqlserver中怎么样解决复杂查询的问题?
- sql-server – 如何在SQL Server 2017中使用SNAPSHOT_MATER
- sqlserver 文件数据库和关系数据库的对比
- SQL数据库备份怎样做?数据库备份代码解析
- 数据库 – 查询最后一天,上周,上个月的SQLite
- sql中identity自增的方法是什么?


