使用可选排序字段组织数据库表中的数据时,通常将空值放在最后。然而,有时特定值需要例外。在 PostgreSQL 中,出现了将空值排序在非空值之后的要求,-1 是一个例外,应该出现在所有其他值之后。
为了实现这一点,出现了一个简单的解决方案:
SELECT * FROM tasks ORDER BY (sort IS NOT DISTINCT FROM -1), sort;
Postgres 将布尔值视为一种类型,包括 NULL。其默认排序顺序为:
在表达式 (sort与 -1 不同),对于除 -1 之外的所有值,条件的计算结果均为 FALSE,-1 的计算结果为 TRUE并排在最后。将其与二次排序相结合,按需要对数据进行排序。
产生相同结果的替代查询是:
SELECT * FROM tasks ORDER BY (sort IS DISTINCT FROM -1) DESC, sort;
通过利用 Postgres 的布尔功能并将其与 ORDER 组合BY子句,可以轻松处理复杂的排序需求。
以上是如何在 PostgreSQL 中对具有特定值异常的空值进行最后排序?的详细内容。更多信息请关注PHP中文网其他相关文章!