首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL查询构建,需要建议

SQL查询构建,需要建议
EN

Stack Overflow用户
提问于 2021-02-01 21:25:42
回答 1查看 17关注 0票数 0

你能帮我解决下面这个问题吗?

我已经通过连接两个三个表来查询结果集,如下所示:

我的要求是在2017年7月1日之后获得两个条目,并在2017年7月1日之前为每个帐户获得两个条目。

例如,附加的屏幕截图,其中绿色行应该出现在最终结果中。

请帮帮忙

EN

回答 1

Stack Overflow用户

发布于 2021-02-01 21:29:02

您可以使用row_number()

代码语言:javascript
复制
with cte as (
      <your query here>
     )
select cte.*
from (select cte.*,
             row_number() over (partition by ac_no, tran_date < '2017-07-01' order by rand()) as seqnum
      from cte
     ) cte
where seqnum <= 2;

注意:这会将2017-07-01的交易放在"after“组中。如果您根本不需要它们,只需在子查询中将它们过滤掉。

SQL Server中的等效逻辑为:

代码语言:javascript
复制
             row_number() over (partition by ac_no, case when tran_date < '2017-07-01' then 1 else 2 end order by newid()) as seqnum
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65993534

复制
相关文章

相似问题

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