亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

ORDER BY 排序

前面小節介紹了如何查詢數據,并且介紹了如何使用 WHERE 條件對查詢的數據結果集進行篩選,本小節介紹如何使用 ORDER BY 對查詢結果集進行排序,排序在實際業務中非常有必要,可以較好地對結果集數據分析和處理。

1.ASC 從小到大排序

ASC 是對結果集按照字段從小到大排序(升序),以 teacher 表為例,將查詢出來的所有結果集按照年齡 age 從小到大排序:

 SELECT * FROM teacher ORDER BY age ASC;

執行結果如下圖:

圖片描述

2.DESC 從大到小排序

DESC 是對結果集按照字段從大到小排序(降序),以 teacher 表為例,將查詢出來的所有結果集按照年齡 id 從大到小排序:

 SELECT * FROM teacher ORDER BY id DESC;

執行結果如下圖:

圖片描述

3.使用多字段混合排序

以 teacher 表為例,將查詢出來的結果集按照 age 從大到小排序之后,再按照 id 字段從小到大排序:

SELECT * FROM teacher ORDER BY age DESC,id ASC;

執行結果如下圖:

圖片描述

4.對字符串類型字段排序

前面排序的 age 和 id 字段是 int 類型,為了演示方便這里先插入幾個 name 字段為英文名的教師測試數據,并對 name 字段排序,插入數據 SQL 語句如下:

INSERT INTO teacher
(name,age,id_number,email)
VALUES'Tom',22,'42011720200604077X''[email protected]'),
('Jack',23,'42011720200604099X''[email protected]'),
('Mary',24,'42011720200604020X','[email protected]'),
('Timo',25,'42011720200604022X','[email protected]'),
('Faker',21,'42011720200604033X','[email protected]';

對查詢結果集按照 name 字段 ASC 升序排序:

SELECT * FROM teacher ORDER BY name ASC;

執行結果如下圖:

圖片描述

Tips:如上圖所示,使用 ASC 對結果集按照 name 字段升序,其實是對 name 字段字符串編碼的排序,英文字符排序在前,中文在后,其中排序規則是按照字符 ASCII碼 對應值的大小排序的。

5.小結

本小節介紹了如何使用 ORDER BY 對查詢結果集按照值字段排序,其中包括 ASC 升序和 DESC 降序,需要注意的是各種數據的字符集可能不同,如中文字符編碼 GBK編碼、utf-8編碼, 若需要經常對字符串類型字段進行排序,可以給該字符串字段加上普通 Bree索引,二級索引樹字符串默認存儲方式是按照字符集升序存儲的(MySQL8.0 可自定義排序存儲方式),所以有索引的字段排序性能比沒有索引的字段排序性能好。