将列组和分区查询转换为SqlAlchemy

2024-05-14 06:05:36 发布

您现在位置:Python中文网/ 问答频道 /正文

我想将以下查询转换为SqlAlchemy,但文档不是很有用:

select * from (
select *, 
RANK() OVER (PARTITION BY id ORDER BY date desc) AS RNK 
from table1
) d
where RNK = 1

有什么建议吗?在


Tags: from文档iddatebysqlalchemyasorder
1条回答
网友
1楼 · 发布于 2024-05-14 06:05:36

使用^{}表达式

from sqlalchemy import func

subquery = db.session.query(
    table1,
    func.rank().over(
        order_by=table1.c.date.desc(),
        partition_by=table1.c.id
    ).label('rnk')
).subquery()

query = db.session.query(subquery).filter(
    subquery.c.rnk==1
)

相关问题 更多 >