你能帮我解决下面这个问题吗?
我已经通过连接两个三个表来查询结果集,如下所示:

我的要求是在2017年7月1日之后获得两个条目,并在2017年7月1日之前为每个帐户获得两个条目。
例如,附加的屏幕截图,其中绿色行应该出现在最终结果中。
请帮帮忙
发布于 2021-02-01 21:29:02
您可以使用row_number()
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中的等效逻辑为:
row_number() over (partition by ac_no, case when tran_date < '2017-07-01' then 1 else 2 end order by newid()) as seqnumhttps://stackoverflow.com/questions/65993534
复制相似问题