首页 > 数据库 > mysql教程 > 如何在 PostgreSQL 中对最后一个空值和倒数第二个特定值进行排序?

如何在 PostgreSQL 中对最后一个空值和倒数第二个特定值进行排序?

DDD
发布: 2024-12-29 03:12:11
原创
446 人浏览过

How to Sort Nulls Last and a Specific Value Second to Last in PostgreSQL?

如何在特殊情况下对空值进行排序

问题:

当使用可选排序字段(sort)对 PostgreSQL 表进行排序时,如何确保即:

  • 排序中的空值在所有非空值之后排序。
  • 排序中特殊值 -1 在常规非空值之后但在空值之前排序。

解决方案:

使用以下SQL语句:

SELECT *
FROM tasks
ORDER BY (sort IS NOT DISTINCT FROM -1), sort;
登录后复制

解释:

  • 表达式(排序与 -1 不不同)的计算结果为:

    • 对于所有排序值均为 FALSE,除了-1.
    • 对于 sort = -1 为 TRUE。
  • 按此表达式排序首先将值分为两类:sort = -1 和所有其他排序值。
  • 按每个内的排序顺序进行二次排序类别。

示例:

考虑以下示例数据:

id | f_id |   name   | sort
---+------+----------+-------
 1 |    1 | zeta     |    -1
 2 |    1 | alpha    |     1
 3 |    1 | gamma    |     3
 4 |    1 | beta     |     2
 5 |    1 | delta    |     
 6 |    1 | epsilon  |     
登录后复制

查询将生成以下排序结果:

id | f_id |   name   | sort
---+------+----------+-------
 2 |    1 | alpha    |     1
 4 |    1 | beta     |     2
 3 |    1 | gamma    |     3
 5 |    1 | delta    |     
 6 |    1 | epsilon  |     
 1 |    1 | zeta     |    -1
登录后复制

以上是如何在 PostgreSQL 中对最后一个空值和倒数第二个特定值进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

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