首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >删除sql server中的重复行

删除sql server中的重复行
EN

Stack Overflow用户
提问于 2014-03-08 18:31:53
回答 1查看 178关注 0票数 0

我有一个具有以下示例格式的表:

代码语言:javascript
运行
复制
ID Name 
1  NULL
1  NULL
2  HELLO 
3  NULL
3  BYE

我的目标是用相同的IDS删除重复的行,但使用限制。根据这个例子,我需要删除ID-1的行和ID-3且没有值(NULL)的行。

我会坚持在桌子上:

代码语言:javascript
运行
复制
ID Name 
1  NULL
2  HELLO 
3  BYE

我如何在sql server中做到这一点?谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-03-08 18:45:44

要选择数据,可以使用一个简单的CTE (公共表表达式);

代码语言:javascript
运行
复制
WITH cte AS (
  SELECT id, name,
    ROW_NUMBER() OVER (PARTITION BY id ORDER BY name DESC) rn
  FROM myTable
)
SELECT id,name FROM cte WHERE rn=1;

一个要测试的SQLfiddle

如果您的意思是删除表中的重复项,而不只是选择数据而不更新任何内容,则可以使用相同的CTE;

代码语言:javascript
运行
复制
WITH cte AS (
  SELECT id, name,
    ROW_NUMBER() OVER (PARTITION BY id ORDER BY name DESC) rn
  FROM myTable
)
DELETE FROM cte WHERE rn<>1;

要测试的另一个SQLfiddle,并记住在运行来自Internet上随机人员的破坏性SQL语句之前始终备份数据。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22273367

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档