【问题标题】:How to group results to boolean value in PostgreSQL如何在 PostgreSQL 中将结果分组为布尔值
【发布时间】:2017-02-23 17:01:02
【问题描述】:

我有一个返回的查询

Select bool_val
from .....

查询返回许多值为TrueFalse 的行或根本没有行。

我希望查询始终返回TrueFalse,条件是如果有一个为真,则结果为True,否则为False

例如: 查询结果:

False
False
True
False

应该返回True

查询结果:

False
False

应该返回False

查询结果:

no rows

应该返回False,因为查询是空的。

在没有IFs 的情况下,如何使用 PostgreSQL 进行查询?

【问题讨论】:

    标签: sql postgresql


    【解决方案1】:

    您可以使用布尔聚合:

    select bool_or(bool_val)
    from the_table;
    

    若要在表不包含任何行时也获得 false,请使用 coalesce()(感谢 Elad)

    select coalesce(bool_or(bool_val), false)
    from the_table;
    

    另一个 - 可能更快 - 选项是:

    select exists (select 1 from the_table where bool_val)
    

    【讨论】:

    • 如果使用select coalesce(bool_or(bool_val),False) from the_table...;也可以避免联合,coalesce将处理没有返回行的情况。
    猜你喜欢
    • 2015-03-26
    • 2019-06-11
    • 2012-10-01
    • 2015-09-29
    • 2020-12-10
    • 1970-01-01
    • 2015-06-17
    • 2022-10-08
    • 1970-01-01
    相关资源
    最近更新 更多