龙空技术网

一文讲懂 SQL 排序子句 ORDER BY

程序员喵宁一 228

前言:

今天各位老铁们对“sql查询倒序排序”大体比较关心,咱们都想要分析一些“sql查询倒序排序”的相关知识。那么小编也在网络上搜集了一些关于“sql查询倒序排序””的相关内容,希望兄弟们能喜欢,兄弟们一起来学习一下吧!

大家好,我是宁一。

今天是SQL教程的第六课,来看看ORDER BY 排序子句。

ORDER BY语句是用来排序的,后面跟的是字段名。

基本语法:

SELECT <字段名> FROM <表名> ORDER BY <字段名>;

1、ORDER BY 后面可以:

* 是表中现有的列名;

* 给数字排序,也可以给字符、文字排序;

* ASC是升序排序(默认),DESC是倒序排序。

实例:将Students学生表根据性别排序。

SELECT *FROM StudentsORDER BY Ssex;

2、ORDER BY 后面还可以:

* 跟多个字段名,字段名之间用英文逗号隔开;

* 任何一个字段名后面都可以加降序排序(DESC);

字段的顺序很重要,会先根据第一个字段排序,第一个字段相同的,再根据第二个字段排序。

实例:将Students学生表根据性别Ssex倒序排序,再根据Sage升序排序。

SELECT *FROM StudentsORDER BY Ssex DESC,Sage;

3、MySQL特性

在MySQL中,ORDER BY 后面可以:

* 用任何列排序,不管那列是不是在SELECT子句中。

* 用列别名排序;

实例:

SELECT Sname,Sid+100 AS "新编号"FROM StudentsORDER BY Ssex,"新编号";

这两个分别是未在SELECT子句中的列 和 别名列,都用到了 MySQL 特性,要是在其他数据库管理系统中写这样的查询可能就会报错。

作业:在Scores成绩表中,将课程编号(Cid)为1的记录,根据分数(score)倒序排序。

答案解析:需要用WHERE来判断课程编号(Cid)为1,ORDER BY子句放在WHERE子句的后面。

SELECT *FROM ScoresWHERE Cid = 1ORDER BY score DESC;

下节课开始我们第七课的学习,来看看LIMIT子句的用法。

关注一下,学习SQL不迷路~

标签: #sql查询倒序排序 #sql倒序排列语句 #数据库倒序排列语句 #倒序排列sql语句 #倒序排列sql语句有哪些