返回介绍

I. 教程

II. SQL 语言

III. 服务器管理

IV. 客户端接口

V. 服务器端编程

VI. 参考手册

VII. 内部

VIII. 附录

7.5. 行排序

发布于 2019-09-30 03:06:04 字数 1675 浏览 835 评论 0 收藏 0

在查询生成输出表之后,也就是在处理完选择列表之后,你还可以对输出表进行排序。如果没有排序,那么行将以不可预测的顺序返回(实际顺序将取决于扫描和连接规划类型和在磁盘上的顺序,但是肯定不能依赖这些东西)。确定的顺序只能在明确地使用了排序步骤之后才能保证。

ORDER BY 子句用于声明排序顺序

SELECT select_list
    FROM table_expression
    ORDER BY sort_expression1 [ASC | DESC] [, sort_expression2 [ASC | DESC] ...]

sort_expression 是任何可用于选择列表的表达式,例如:

SELECT a, b FROM table1 ORDER BY a + b, c;

如果指定了多个排序表达式,那么仅在前面的表达式排序相等的情况下才使用后面的表达式做进一步排序。每个表达式都可以跟一个可选的 ASC(升序,默认) 或 DESC(降序)以设置排序方向。升序先输出小的数值,这里的"小"是以 < 操作符的角度定义的。类似的是,降序是以 > 操作符来判断的。[1]

为了向后兼容 SQL92 标准,sort_expression 也可以使用字段名或者字段编号,比如下面两句

SELECT a + b AS sum, c FROM table1 ORDER BY sum;
SELECT a, max(b) FROM table1 GROUP BY a ORDER BY 1;

都按照第一个字段进行排序。需要注意的是,输出字段名必须是独立的(不允许作为排序表达式的一部分)。比如,下面的语句是错误的。

SELECT a + b AS sum, c FROM table1 ORDER BY sum + c;          -- 错误的

这样的限制主要是为了避免歧义。另外,如果某个排序表达式能够同时匹配输出字段名和表表达式中的字段名,也会导致歧义(此时使用输出字段名)。当然,这种情况仅在你使用了 AS 重命名输出字段并且恰好与其它表的字段同名的时候才会发生。

ORDER BY 可以应用于 UNION, INTERSECT, EXCEPT 的计算结果,不过在这种情况下,只允许按照字段的名字或编号进行排序,而不允许按照表达式进行排序。

注意

[1]

事实上,PostgreSQL 使用默认的B-tree操作符类 为表达式的数据类型确定 ASCDESC排序顺序。一般来说,数据类型将被转换为适合于 <> 操作符进行排序。但是对于用户自定义的数据类型可以不必如此。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文