MySQL基础知识——ORDER BY
点击关注上方“SQL数据库开发”,
设为“置顶或星标”,第一时间送达干货
ORDER BY作用
ORDER BY 关键字用于对结果集进行排序。
ORDER BY 关键字
ORDER BY 关键字用于按升序(ASC)或降序(DESC)对结果集进行排序。
ORDER BY 关键字默认情况下按升序(ASC)排序记录,默认排序可以不写ASC。
如果需要按降序对记录进行排序,可以使用DESC关键字,不可省略。
ORDER BY 语法
SELECT column1, column2, ... FROM table_name
ORDER BY column1, column2, ... ASC|DESC;
示例数据库
以下是 "Customers" 表中的数据:
ORDER BY 实例
下面的 SQL 语句从 "Customers" 表中选取所有客户,并按照 "省份" 列排序:
实例:
SELECT * FROM Customers
ORDER BY 省份;
结果:
这里排序方式默认是升序。这里排序规则,是按照省份里的拼音首字母的ASCII规则排序的。例如北京市首字母是B,广东省的首字母是G,湖北省的首字母是H,上海市的首字母是S,浙江省的首字母是Z。排序后就是上述结果了,如果排序的首字母相同,则比较第二位字母,依次类推。
ORDER BY DESC 实例
下面的 SQL 语句从 "Customers" 表中选取所有客户,并按照 "省份" 列降序排序:
实例:
SELECT * FROM Customers
ORDER BY 省份 DESC;
结果:
加了DESC后排序方式变成了降序,排序规则与升序相反。
ORDER BY 多列 实例
为了让大家更加好理解,我们在Customers表中添加两行数据。
INSERT INTO `Customers` (客户ID,姓名,地址,城市,邮编,省份)
VALUES
( 6, '宋一', '花城大道21号', '广州', '510000', '广东省' );
INSERT INTO `Customers` (客户ID,姓名,地址,城市,邮编,省份)
VALUES
( 7, '刘二', '长安街121号', '北京', '100000', '北京市' );
添加数据后的Customers表如下:
下面的 SQL 语句从 "Customers" 表中选取所有客户,并按照 "省份" 和 "姓名" 列排序:
示例
SELECT * FROM Customers
ORDER BY 省份, 姓名;
结果:
可以看到,对省份排序的时候,北京市和广东省各出现了两条。这时候再对姓名这一列的拼音首字母进行排序。在省份一致的前提下,刘二的首字母是L,赵七的首字母是Z,所以刘二排在赵七的前面。同理宋一的首字母是S,王五的首字母是W,所以宋一排在王五的前面。
ORDER BY 多列 实例2
以下SQL语句从"Customers" 表中选择所有客户,按 "省份" 升序排列,并按 "姓名" 列降序排列:
SELECT * FROM Customers
ORDER BY 省份 ASC, 姓名 DESC;
结果:
对姓名进行降序排列后,姓名的排序结果与升序相反。
SELECT * FROM Customers
ORDER BY `省份`
LIMIT 3
结果为:
结果只显示了排好序的前三位客户信息。
——End——
后台回复关键字:1024,获取一份精心整理的技术干货 后台回复关键字:进群,带你进入高手如云的交流群。 推荐阅读 这是一个能学到技术的公众号,欢迎关注
点击「阅读原文」了解SQL训练营