yuyu

若在你的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条,分别是

 

 

 

分类:

技术点:

相关文章:

  • 2021-07-20
  • 2021-12-05
  • 2022-01-25
  • 2021-10-30
  • 2022-02-05
  • 2022-01-07
  • 2021-07-13
  • 2022-12-23
猜你喜欢
  • 2021-06-26
  • 2021-11-25
  • 2022-01-21
  • 2022-12-23
  • 2021-04-03
相关资源
相似解决方案