mysql学习教程,从入门到精通,SQL ORDER BY 子句(14)

1、SQL ORDER BY 子句

在本教程中,您将学习如何对SELECTSQL查询返回的数据进行排序。

1.1、对结果集排序

通常,当您使用SELECT语句从表中获取数据时,结果集中的行没有任何特定的顺序。如果要按特定顺序排列结果集,则可以在语句末尾指定ORDER BY子句,该子句告诉程序如何对查询返回的数据进行排序。默认排序顺序为升序。

1.2、语法

ORDER BY子句用于按升序或降序对查询返回的数据进行排序。该子句的基本语法可以通过以下方式给出:

sql 复制代码
SELECT column_list FROM table_name ORDER BY column_name ASC|DESC;

在这里,column_list是要获取其值的数据库表的名称,年龄,国家等列/字段的名称,而column_name是要排序的列的名称。让我们看一些示例,演示其实际工作方式。

考虑我们在数据库中有一个employees表,该表具有以下记录:

1.3、单列排序

下面的SQL语句将从employees表中返回所有employee,并按emp_name列的升序对结果集进行排序。

sql 复制代码
SELECT * FROM employees 
ORDER BY emp_name ASC;

您可以跳过该ASC选项,而仅使用以下语法。它返回与上一条语句相同的结果集,因为SQL默认排序顺序是升序的:

sql 复制代码
SELECT * FROM employees 
ORDER BY emp_name;

执行上述命令后,您将获得如下输出:

同样,您可以使用DESC选项以降序执行排序。以下语句将按数字薪水(salary)列的降序排列结果集。

sql 复制代码
SELECT * FROM employees 
ORDER BY salary DESC;

这次,您将获得如下结果集:

1.4、多列排序

您还可以在排序时指定多个列。但是,除非表中有一些重复的值,否则结果集的更改将不可见。好吧,让我们找出:

为了更好地理解多列排序,我们假设我们在数据库中有一个名为Trainees的表,其中包含以下记录:

如果您仔细查看表格,将会发现我们有一些重复的值。但是,受训者 Peter Parker 和 Peter Pan 的全名不同,但名字相同。

现在执行以下命令,该命令按first_name列对结果集进行排序。

sql 复制代码
SELECT * FROM trainees 
ORDER BY first_name;

执行后,您将获得如下输出:

现在执行此语句,该语句按first_name和last_name列对结果集进行排序。

sql 复制代码
SELECT * FROM trainees 
ORDER BY first_name, last_name;

您是否注意到以前的结果集和当前的结果集之间的区别-这次,学员" Peter Parker"的记录紧随" Peter Pan"之后。

由于两个受训者的名字都是" Peter",因此在这两个受训者的last_name列执行第二级排序,这就是为什么受训者" Peter Parker"的记录在" Peter Pan"之后。

相关推荐
HaoHao_010几秒前
如何将MySQL数据库迁移至阿里云
服务器·数据库·阿里云·云计算·云服务器·迁移
Мартин.2 分钟前
[Meachines] [Easy] Wifinetic FTP匿名登录+Reaver WPS PIN密码泄露权限提升
数据库·postgresql·wps
茂桑6 分钟前
MVCC(多版本并发控制)
java·开发语言·数据库
卷心菜不卷Iris33 分钟前
第1章大型互联网公司的基础架构——1.9 LSM Tree
数据库·lsm-tree·互联网大厂·基础架构
小赖同学啊40 分钟前
jmeter 与大数据生态圈中的服务进行集成
大数据·jmeter
thinkMoreAndDoMore1 小时前
深度学习(3)-TensorFlow入门(常数张量和变量)
开发语言·人工智能·python
杰九1 小时前
【环境配置】maven,mysql,node.js,vue的快速配置与上手
java·vue.js·spring boot·mysql·node.js·maven
闲人编程1 小时前
Spark单机快速入门:从部署到数据分析实战
大数据
GISer_Qing1 小时前
ASP.NET Core 8.0学习笔记(二十七)——数据迁移:Migrations深入与其他迁移命令
数据库·c#·.netcore·entityframework
蓝桉8021 小时前
图片爬取案例
开发语言·数据库·python