首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PostgreSQL聚合的SQLAlchemy操作符(每一个)

PostgreSQL聚合的SQLAlchemy操作符(每一个)
EN

Stack Overflow用户
提问于 2015-06-10 12:23:57
回答 1查看 146关注 0票数 2

PostreSQL的特性是 aggregate functions,它通过在所有组行上运行谓词来过滤组。

例如,下表:

代码语言:javascript
复制
 star_name | star_type | landed_upon
-----------+-----------+-------------
 Mars      | Planet    | t
 Venus     | Planet    | t
 Rhea      | Moons     | f
 Titan     | Moons     | t

这个every()查询:

代码语言:javascript
复制
SELECT star_type, max(star_name) example, COUNT(*)
    FROM stars
    GROUP BY star_type
    HAVING every (landed_upon = true);

返回Planet组,但不返回Moons组,因为Rhea不满足Moons组中的landed_upon谓词:

代码语言:javascript
复制
 star_type | example | count
-----------+---------+-------
 Planet    | Venus   |     2
(1 row)

对于PostgreSQL every()有等效的PostgreSQL运算符吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-06-12 13:06:10

可以使用func对象生成SQL函数。

代码语言:javascript
复制
.having(func.every(Star.landed_upon))

会产生

代码语言:javascript
复制
HAVING EVERY(stars.landed_upon)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30756284

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档