MySQL中的排序(ORDER BY)
当使用 SELECT FROM 时,如果不排 序,数据一般将以它在底层表中出现的顺序显示。这可以是数据最初添加到表中的顺序。但是,如果数据后来进行过更新或删除,则此顺 序将会受到MySQL重用回收存储空间的影响。因此,如果不明确控 制的话,不能(也不应该)依赖该排序顺序。关系数据库设计理论认 为,如果不明确规定排序顺序,则不应该假定检索出的数据的顺序有 意义。 《MySQL必知必会》
可以使用 ORDER BY 子句取一列或者多列的名字,据此对输出进行排序,比如创建了如下的student表:
创建表:
CREATE TABLE stu
(Cno SMALLINT,
Sno CHAR(11) PRIMARY KEY,
Sname CHAR(20) UNIQUE,
Ssex CHAR(2),
Sage SMALLINT);
插入数据:
insert into stu values(5,'20162180111','萧峰','男',22);
insert into stu values(4,'20162180108','张无忌','男',21);
insert into stu values(3,'20162180222','王语嫣','女',21);
insert into stu values(5,'20162180088','郭襄','女',19);
insert into stu values(5,'20162180067','袁紫衣','女',21);
insert into stu values(3,'20162180023','赵敏','女',20);
想依据Sno(学号)对输出进行排序, SELECT * FROM stu ORDER BY Sno; 得到以下排序后的输出。
但是,经常需要按不止一个列进行数据排序。比如想对上述表中的数据先进行班排序,然后在班内进行学号的排序,操作语句如下:
SELECT * FROM stu ORDER BY Cno,Sno;
但是应该注意到,这种多列一起排序的情况,以2列为例,如果第一列中的所有值都不相同,那么第二列中的排序就没有意义了,如,所有的人都来自不同班,那么按班号排序后就无须再按学号排序了。
ORDER BY 默认的排序是升序的,也可以改为降序,操作语句如下:
SELECT * FROM stu ORDER BY Sno DESC;
当然,同理,想先按班级号升序排序,然后再在班内按学号降序排序的操作如下:
SELECT * FROM stu ORDER BY Cno,Sno DESC;
由此可以看到,DESC关键字只应用到直接位于其前面的列名。
使用ORDER BY 和 LIMIT 可以找出一个列中最高或者最低的值
比如,想找出学生中学号最高的那位同学,操作语句如下:
SELECT * FROM stu ORDER BY Sno DESC LIMIT 1;
注意:ORDER BY子句的位置 在给出ORDER BY子句时,应该保证它 位于FROM子句之后。如果使用LIMIT,它必须位于ORDER BY 之后。使用子句的次序不对将产生错误消息
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架