首页 >数据库 >mysql教程 >如何在 PostgreSQL 中对具有特定值异常的空值进行最后排序?

如何在 PostgreSQL 中对具有特定值异常的空值进行最后排序?

Barbara Streisand
Barbara Streisand原创
2024-12-29 11:44:18518浏览

How to Sort Nulls Last in PostgreSQL with a Specific Value Exception?

排序:除特殊例外外均为空

使用可选排序字段组织数据库表中的数据时,通常将空值放在最后。然而,有时特定值需要例外。在 PostgreSQL 中,出现了将空值排序在非空值之后的要求,-1 是一个例外,应该出现在所有其他值之后。

为了实现这一点,出现了一个简单的解决方案:

SELECT *
FROM   tasks
ORDER  BY (sort IS NOT DISTINCT FROM -1), sort;

Postgres 将布尔值视为一种类型,包括 NULL。其默认排序顺序为:

  • FALSE (0)
  • TRUE (1)
  • NULL

在表达式 (sort与 -1 不同),对于除 -1 之外的所有值,条件的计算结果均为 FALSE,-1 的计算结果为 TRUE并排在最后。将其与二次排序相结合,按需要对数据进行排序。

产生相同结果的替代查询是:

SELECT *
FROM   tasks
ORDER  BY (sort IS DISTINCT FROM -1) DESC, sort;

通过利用 Postgres 的布尔功能并将其与 ORDER 组合BY子句,可以轻松处理复杂的排序需求。

以上是如何在 PostgreSQL 中对具有特定值异常的空值进行最后排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn