MySQL 8.3 Release Notes
您可能已经注意到,在前面的示例中,结果行是以无特定顺序显示的。通常,查询输出更易于检查时,行是按某种有意义的方式排序的。要排序结果,使用 ORDER BY
子句。
这里是动物生日,按日期排序:
mysql> SELECT name, birth FROM pet ORDER BY birth;
+----------+------------+
| name | birth |
+----------+------------+
| Buffy | 1989-05-13 |
| Bowser | 1989-08-31 |
| Fang | 1990-08-27 |
| Fluffy | 1993-02-04 |
| Claws | 1994-03-17 |
| Slim | 1996-04-29 |
| Whistler | 1997-12-09 |
| Chirpy | 1998-09-11 |
| Puffball | 1999-03-30 |
+----------+------------+
在字符类型列上,排序——像所有其他比较操作一样——通常以不区分大小写的方式进行。这意味着,对于仅在大小写方面不同的列,顺序是未定义的。您可以使用 BINARY
强制某列的区分大小写排序,例如:ORDER BY BINARY
。col_name
默认的排序顺序是升序,最小的值首先。要按降序(降序)排序,请将 DESC
关键字添加到要排序的列名中:
mysql> SELECT name, birth FROM pet ORDER BY birth DESC;
+----------+------------+
| name | birth |
+----------+------------+
| Puffball | 1999-03-30 |
| Chirpy | 1998-09-11 |
| Whistler | 1997-12-09 |
| Slim | 1996-04-29 |
| Claws | 1994-03-17 |
| Fluffy | 1993-02-04 |
| Fang | 1990-08-27 |
| Bowser | 1989-08-31 |
| Buffy | 1989-05-13 |
+----------+------------+
您可以对多个列进行排序,并且可以对不同的列进行不同方向的排序。例如,要按动物类型升序排序,然后按出生日期降序排序(最年轻的动物首先),请使用以下查询:
mysql> SELECT name, species, birth FROM pet
ORDER BY species, birth DESC;
+----------+---------+------------+
| name | species | birth |
+----------+---------+------------+
| Chirpy | bird | 1998-09-11 |
| Whistler | bird | 1997-12-09 |
| Claws | cat | 1994-03-17 |
| Fluffy | cat | 1993-02-04 |
| Fang | dog | 1990-08-27 |
| Bowser | dog | 1989-08-31 |
| Buffy | dog | 1989-05-13 |
| Puffball | hamster | 1999-03-30 |
| Slim | snake | 1996-04-29 |
+----------+---------+------------+
DESC
关键字仅应用于其前面的列名(birth
);它不影响 species
列的排序顺序。