您的位置:首页 > 其它

如何删除表的重复行

2010-06-22 11:00 148 查看
如何删除SQL Server表中的重复行

若在你的MS Sql Server数据库表中,有重复的多行,你可能想去删除这些重复的记录。

T_SQL Row_Number()函数能帮助sql开发者去解决这个sql的问题。

1.创建TUser表:

CREATE TABLE TUser(

Name varchar(50),

Region varchar(50),

Remark varchar(100)

)

2.插入重复数据到TUser表中

INSERT TUser VALUES ('Tom','Franc', 'test1')

INSERT TUser VALUES ('Kate','China', 'test2')

INSERT TUser VALUES ('Tom','Japan', 'test3')

INSERT TUser VALUES ('Mary','Japan', 'test4')

INSERT TUser VALUES ('Tom','German', 'test5')

3.[b]筛选数据
[/b]

SELECT RN=ROW_NUMBER() OVER (ORDER BY name)

FROM TUser where Name='Tom'

4.概要-删除表中重复的行

TUser表中有3条重复的数据,我们现在希望删掉前2条,保留第3条

WITH [CTE DUPLICATE] as

(SELECT RN=ROW_NUMBER() OVER (ORDER BY name)

FROM TUser where Name='Tom'

)

delete from [CTE DUPLICATE] where RN<3

执行该sql语句后,数据库中记录有5条变为3条,分别是



学习,备用!

/article/5900069.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: