• 博客园logo
  • 会员
  • 周边
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • YouClaw
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
向往
博客园    首页    新随笔    联系   管理    订阅  订阅

删除SQL表中重复行的方法

在建立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条,分别是

 

 

文章转载自网管之家:http://www.bitscn.com/pdb/mssql/201010/191425.html

posted on 2011-10-21 21:03  向往  阅读(883)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2026
浙公网安备 33010602011771号 浙ICP备2021040463号-3