【问题标题】:Convert rank and partition query to SqlAlchemy将等级和分区查询转换为 SqlAlchemy
【发布时间】:2016-11-16 14:48:34
【问题描述】:

我想将以下查询转换为 SqlAlchemy,但文档帮助不大:

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

有什么建议吗?

【问题讨论】:

    标签: python sql sqlalchemy


    【解决方案1】:

    使用over 表达式

    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
    )
    

    【讨论】:

      猜你喜欢
      • 2017-04-25
      • 1970-01-01
      • 2019-03-20
      • 1970-01-01
      • 2021-11-03
      • 2015-01-31
      • 2019-02-05
      • 2017-02-01
      • 1970-01-01
      相关资源
      最近更新 更多