MySQL 排序: ORDER BY 语句
一则或许对你有用的小广告
欢迎加入小哈的星球 ,你将获得:专属的项目实战 / 1v1 提问 / Java 学习路线 / 学习打卡 / 每月赠书 / 社群讨论
- 新项目:《从零手撸:仿小红书(微服务架构)》 正在持续爆肝中,基于
Spring Cloud Alibaba + Spring Boot 3.x + JDK 17...
,点击查看项目介绍 - 《从零手撸:前后端分离博客项目(全栈开发)》 2 期已完结,演示链接: http://116.62.199.48/
截止目前, 星球 内专栏累计输出 66w+ 字,讲解图 2896+ 张,还在持续爆肝中.. 后续还会上新更多项目,目标是将 Java 领域典型的项目都整一波,如秒杀系统, 在线商城, IM 即时通讯,权限管理,Spring Cloud Alibaba 微服务等等,已有 2300+ 小伙伴加入学习 ,欢迎点击围观
在 SQL 查询中,ORDER BY
子句用于对查询结果集按照指定列进行排序,以便得到更直观的输出。排序可以是升序或降序。默认情况下,ORDER BY
会对数据进行升序排序;若想使用降序,则需显式指定。
1. ORDER BY 基本语法
SELECT 列名1, 列名2, ...
FROM 表名
ORDER BY 列名1 [ASC|DESC], 列名2 [ASC|DESC], ...;
- ASC:升序排列(默认);
- DESC:降序排列;
2. ORDER BY 示例
假设我们有一个 students
表,数据如下:
id | name | age | grade |
---|---|---|---|
1 | Alice | 20 | 85 |
2 | Bob | 18 | 92 |
3 | Carol | 21 | 78 |
4 | Dave | 19 | 88 |
示例 1:单列排序
如果想按照 age
年龄列对学生进行升序排列,可以使用以下查询:
SELECT * FROM students
ORDER BY age;
查询结果:
id | name | age | grade |
---|---|---|---|
2 | Bob | 18 | 92 |
4 | Dave | 19 | 88 |
1 | Alice | 20 | 85 |
3 | Carol | 21 | 78 |
示例 2:降序排序
若想按 grade
列降序排列学生的成绩,则可以指定 DESC
:
SELECT * FROM students
ORDER BY grade DESC;
查询结果:
id | name | age | grade |
---|---|---|---|
2 | Bob | 18 | 92 |
4 | Dave | 19 | 88 |
1 | Alice | 20 | 85 |
3 | Carol | 21 | 78 |
示例 3:多列排序
可以按照多个列排序,先按 grade
降序排列,如果分数相同,再按 age
升序排列:
SELECT * FROM students
ORDER BY grade DESC, age ASC;
查询结果:
id | name | age | grade |
---|---|---|---|
2 | Bob | 18 | 92 |
4 | Dave | 19 | 88 |
1 | Alice | 20 | 85 |
3 | Carol | 21 | 78 |
3. 使用别名进行排序
在查询中为列设置别名后,可以直接用别名进行排序。例如,将 grade
列的别名设置为 score
,然后按 score
降序排序:
SELECT id, name, age, grade AS score
FROM students
ORDER BY score DESC;
4. ORDER BY 与 NULL 值
在排序时,NULL
值通常会被放在最后。如果要将 NULL
值放在最前或其他特定位置,一些数据库(如 MySQL)允许使用 IS NULL
排序:
SELECT * FROM students
ORDER BY grade IS NULL, grade DESC;
此查询会先将 NULL
值放在开头,然后对非 NULL
的成绩按降序排列。
5. ORDER BY 的性能优化
-
索引:对经常用于排序的列添加索引,可以提高
ORDER BY
的效率。 -
LIMIT:结合
LIMIT
子句,可以避免对整个结果集进行排序,提高查询速度。例如:SELECT * FROM students ORDER BY grade DESC LIMIT 5;
-
避免使用函数:在排序的列上避免使用计算或函数,这会导致索引失效。
6. 小结
ORDER BY
用于按照指定列对查询结果排序。- 可以按单列或多列排序,并指定升序(
ASC
)或降序(DESC
)。 - 使用别名排序可以提高查询的可读性。
- 结合
LIMIT
、索引等方法可以优化排序查询的性能。
通过合理地使用 ORDER BY
,可以使数据更有条理地展示,帮助更直观地理解查询结果。