SQL Server 删除Table表中的重复行的方法
发布时间:2020-12-12 07:56:41 所属栏目:MsSql教程 来源:网络整理
导读:感兴趣的小伙伴,下面一起跟随编程之家 jb51.cc的小编两巴掌来看看吧! 利用SQL Server 2005的新功能NOW_NUMBER和CTE可以很好的实现. 举例说明如下: 建立测试数据: 代码如下: create table Dup1 ( Col1 int null,Col2 varchar(20) null ) insert into Dup1 v
感兴趣的小伙伴,下面一起跟随编程之家 52php.cn的小编两巴掌来看看吧! 利用SQL Server 2005的新功能NOW_NUMBER和CTE可以很好的实现.举例说明如下: 建立测试数据: 代码如下:
可以查看到重复的数据有: 代码如下:
【图片暂缺】 接下来介绍如何delete掉重复的数据: 1.NOW_NUMBER:SQL Server 2005添加了很好用的RANKING函数(NOW_NUMBER,RANK,DENSE_RANK,NTILE),利用NOW_NUMBER()OVER(PARTITION GY)最为直接,也最为方便,不能修改表或者产生多余的列. 首先会分配一个列号码,以Col1,Col2组合来分区排序. 代码如下:
得到的序号如下: 【图片暂缺】 很明显的是重复列都分组分割排序,只需要delete掉排序序号>1的即可. 代码如下:
2.创建一个标识键唯一的表记一列. 代码如下:
删除找出与Col1,Col2相同并且比Dup1.PK大的记录,也就是保留重复值中PK最小的记录. 代码如下:
3.select distant into,这种方法借助一个新的table,把不重复的结果集转移到新table中. 代码如下:
建议采用第一种和第三种方法,第一种多见于T-SQL的编程中,第三种在ETL中常常使用. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |