简单子查询的SQLAlchemy转换

2024-05-19 18:41:51 发布

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

我一直在努力将一个简单的SQL查询转换成一个SQLAlchemy表达式,但我无法按照我在子查询中的意思来处理。这是一个“注释”表的单表查询;我想找出哪些用户第一次发表评论最多:

SELECT user_id, count(*) AS count
FROM comments c
where c.date = (SELECT MIN(c2.date)
                FROM comments c2 
                WHERE c2.post_id = c.post_id
               )
GROUP BY user_id
ORDER BY count DESC
LIMIT 20;

我不知道如何编写子查询以便它引用外部查询,如果我这样做了,我就不知道如何将其组装到外部查询本身中。(使用MySQL,这不重要。)


Tags: 用户fromidsqldatebysqlalchemy表达式
1条回答
网友
1楼 · 发布于 2024-05-19 18:41:51

嗯,在放弃了一段时间后,再回头看看,我想出了一些有效的方法。我相信有更好的办法,但是:

 c2 = aliased(Comment)
 firstdate = select([func.min(c2.date)]).\
       where(c2.post_id == Comment.post_id).\
       as_scalar()  # or scalar_subquery(), in SQLA 1.4

 users = session.query(
    Comment.user_id, func.count('*').label('count')).\
        filter(Comment.date == firstdate).\
        group_by(Comment.user_id).\
        order_by(desc('count')).\
        limit(20)

相关问题 更多 >