首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL Partition by子句

SQL Partition by子句
EN

Stack Overflow用户
提问于 2015-04-24 15:04:25
回答 1查看 380关注 0票数 0

我在结果集的分区中使用SQL语言中的ROW_NUMBER函数,其中我只想要每个分区中的第一行。下面是查询:

代码语言:javascript
复制
Select A, B, C, ROW_NUM
FROM
(SELECT A,B,C, ROW_NUMBER() OVER (PARTITION BY A ORDER BY C DESC) AS R0W_NUM
FROM TABLE 
)X
WHERE ROW_NUM = 1

它会产生预期的结果。

但现在我使用的是FIRST_VALUE函数,如下所示:

代码语言:javascript
复制
SELECT A,B,C, FIRST_VALUE(C) OVER (PARTITION BY A ORDER BY C DESC) AS ROW_NUM
FROM TABLE

但是上面的查询也给了我重复的值。有没有人能指导我怎么去掉那些重复的东西?我尝试使用DISTINCT,但没有帮助。

EN

回答 1

Stack Overflow用户

发布于 2015-04-24 16:52:22

在C上使用FIRST_VALUE不会删除A的重复项。

如果您希望删除A的重复项,则可以使用以下查询之一,具体取决于B的角色。

如果B被视为分区的一部分,则类似于A

代码语言:javascript
复制
Select A, B, MAX(C)
FROM TABLE
GROUP BY A, B

如果B包含可聚合的值(min,max,sum...)类似于C

代码语言:javascript
复制
Select A, MAX(B), MAX(C)
FROM TABLE
GROUP BY A

如果B既不类似于A(可能进行分区),也不类似于C(可能进行聚合),那么我将保留问题中包含的ROW_NUMBER()解决方案。

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

https://stackoverflow.com/questions/29840822

复制
相关文章

相似问题

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