打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
如何删除Table中的重复行 -

如何删除Table中的重复行

上一篇 / 下一篇  2010-06-07 17:27:16 / 个人分类:SQL Server技术

在写SQL的时候经常会有这样的需求: 在一个Table中会有多条重复的数据,如何有效的取出来不重复的数据,或者是删除掉重复的数据,或者取出某列重复值的第一条数据.

利用SQL Server 2005的新功能NOW_NUMBER和CTE可以很好的实现.

举例说明如下:

建立测试数据:

 

可以查看到重复的数据有:

SELECTCol1, Col2,COUNT(*)ASDupCount
FROMDup1
GROUPBYCol1, Col2
HAVINGCOUNT(*)>1

 

接下来介绍如何delete掉重复的数据:

1.NOW_NUMBER:SQL Server 2005添加了很好用的RANKING函数(NOW_NUMBER,RANK,DENSE_RANK,NTILE),利用NOW_NUMBER()OVER(PARTITION GY)最为直接,也最为方便,不能修改表或者产生多余的列.

 首先会分配一个列号码,以Col1,Col2组合来分区排序.

SELECTCol1, Col2,
ROW_NUMBER()
OVER(PARTITIONBYCol1, Col2ORDERBYCol1)ASrn
FROMDup1

 

 

得到的序号如下:

 

很明显的是重复列都分组分割排序,只需要delete掉排序序号>1的即可.

 

--用到CTE
WITHDupsD
AS(
SELECTCol1, Col2,
ROW_NUMBER()
OVER(PARTITIONBYCol1, Col2ORDERBYCol1)ASrn
FROMDup1
)
DELETEDupsD
WHERErn>1;
--或者
DELETEAFROM(
SELECTCol1, Col2,
ROW_NUMBER()
OVER(PARTITIONBYCol1, Col2ORDERBYCol1)ASrn
FROMDup1) AWHEREA.rn>1

 

2.创建一个标识键唯一的表记一列.

 

ALTERTABLEdbo.Dup1
ADD
PK
INTIDENTITY
NOTNULL
CONSTRAINTPK_Dup1PRIMARYKEY;
SELECT*
FROMDup1;

 

 

删除找出与Col1,Col2相同并且比Dup1.PK大的记录,也就是保留重复值中PK最小的记录.

DELETEDup1
WHEREEXISTS(SELECT*
FROMDup1ASD1
WHERED1.Col1=Dup1.Col1
ANDD1.Col2=Dup1.Col2
ANDD1.PK>Dup1.PK );

 

3.select distant into,这种方法借助一个新的table,把不重复的结果集转移到新table中.

 

SELECTdistinctCol1, Col2INTONoDups
FROMDup1;

select*fromNoDups

 

 

 

 建议采用第一种和第三种方法,第一种多见于T-SQL的编程中,第三种在ETL中常常使用.


本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
oracle9i以后排重的好办法
oracle行转列
row_number() over partition by去重复
hive基础 - 心如大海 - JavaEye技术网站
ORACLE创建按月和按天的自动递增分区
分析函数Rownumber,rank,dense_rank
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服