我有一个用户查询,它按每个用户拥有的订单数量(ordersCount)进行过滤。
User.query.filter('ordersCount>2')
如果我运行它,它会显示:“‘where 子句’中的未知列‘ordersCount’”
根据我的经验,我应该在此类操作中使用having,因为mysql不允许它用于不属于表的字段,但如果我使用having而不是过滤器运行它,我会得到:
(1054, "Unknown column 'ordersCount' in 'having clause'") 'SELECT count(1) AS count_1 \nFROM user \nHAVING ordersCount > 2' ()
那么如何在 sqlalchemy 中过滤计数列呢?
请参阅文档排序、分组、限制、偏移... http://www.sqlalchemy.org/docs/core/tutorial.html#ordering-grouping-limiting-offset-ing。根据提供的示例代码并假设您的订单存储在orders
表,您的版本将类似于:
>>> s = select([orders.c.user_id, func.count(orders.c.id)]).\
... group_by(orders.c.user_id).having(func.count(orders.c.id) > 2)
通过这种方式你将得到user_id
相关用户的。如果你想找回User
对象,只需使s
关于子查询并加入您的User
使用此子查询进行查询以检索有问题的用途。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)