在 MySQL SELECT 语句中ORDER BY 子句主要用来将结果集中的数据按照一定的顺序进行排序。
指定用于排序的列可以指定多个列,列名之间用逗号分隔
指定用于排序的表达式。
指定用于排序的列在 SELECT 语句结果集中的位置通常是一个正整数。
关键字 ASC
表示按升序分组关键字 DESC
表示按降序分组,其中 ASC
为默认值这两个关键字必须位于对应的列名、表达式、列的位置之后。
使用 ORDER BY 子句应该注意以下几个方面:
【实例 1】查询 tb_students_info 表的 height 字段值,并对其进行排序输入的 SQL 语句和执行结果如下所示。
以上查询未指定排序的方法则按照默认的ASC升序进行排序;
有时需要根据多列進行排序。对多列数据进行排序要将需要排序的列之间用逗号隔开
1、只对height进行排序时如下:
2、先对height进行排序,再对name进行排序查询结果洳下:
以上查询结果显示,只对height进行排序时Dany排在Anna的前面;将对height和name都进行排序时Anna排在了前面;
提示:前提条件:先排序的height列中Anna和Dany 的height值都是160,所以先进行了height排序再进行name排序。
注意:在对多列进行排序时首行排序的第一列必须有相同的列值,才会对第二列进行排序如果第┅列数据中所有的值都是唯一的,将不再对第二列进行排序
默认情况下,查询数据按字母升序进行排序(A~Z)但数据的排序并不仅限於此,还可以使用 ORDER BY 对查询结果进行降序排序(Z~A)这可以通过关键字 DESC 实现。可以对多列进行不同的顺序排序
注意:DESC 关键字只对前面的列进行降序排列,在这里只对 height 排序而并没有对 name 进行排序,因此height 按降序排序,而 name 仍按升序排序如果要对多列进行降序排序,必须要在烸一列的后面加 DESC 关键字
查询一下新的业务是否正常入库遇到的问题是新旧业务用的是同一个字段标识,唯一不同的是字段里内容的长度不同
查询方式如下mysql按表字段内容长度排序