刪除SQL表中重復(fù)行的方法
若在你的MS Sql Server數(shù)據(jù)庫表中,有重復(fù)的多行,你可能想去刪除這些重復(fù)的記錄。
T_SQL Row_Number()函數(shù)能幫助sql開發(fā)者去解決這個(gè)sql的問題。
1.創(chuàng)建TUser表:
CREATE TABLE TUser(
Name varchar(50),
Region varchar(50),
Remark varchar(100)
)
2.插入重復(fù)數(shù)據(jù)到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.篩選數(shù)據(jù)
SELECT RN=ROW_NUMBER() OVER (ORDER BY name)
FROM TUser where Name='Tom'
4.概要-刪除表中重復(fù)的行
TUser表中有3條重復(fù)的數(shù)據(jù),我們現(xiàn)在希望刪掉前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
執(zhí)行該sql語句后,數(shù)據(jù)庫中記錄有5條變?yōu)?條,分別是