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

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

Barbara Streisand
发布: 2024-12-29 11:44:18
原创
516 人浏览过

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板