如何删除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.篩選數據
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條,分別是
?
?
?
轉載于:https://www.cnblogs.com/yuyu/archive/2010/07/08/1773788.html
總結
以上是生活随笔為你收集整理的如何删除SQL Server表中的重复行的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 谈搜索架构师的不同阶段
- 下一篇: 转:Excel导入SQL数据库完整代码