MySQL如何對數(shù)據(jù)進(jìn)行排序圖文詳解
一、 排序的基本使用
- 在查詢數(shù)據(jù)時(shí),如果沒有使用排序操作,默認(rèn)情況下SQL會(huì)按元組添加的順序來排列查詢結(jié)果。
- 在SQL中,使用關(guān)鍵字 ORDER BY... 來進(jìn)行排序操作。在此關(guān)鍵字后面可以添加關(guān)鍵字 ASC (ascend) 表示升序排列 (從小到大) ,DESC (descend) 表示降序排列 (從大到小) 。
- 如果在 ORDER BY... 關(guān)鍵字后沒有添加 ASC 或 DESC 來指明升序還是降序排列,SQL會(huì)默認(rèn)按照升序 ASC 排列。如下代碼所示:
SELECT employee_id, last_name, salary FROM employees ORDER BY salary;
查詢結(jié)果:

【例子1】查詢員工表 employees 中的員工的 employee_id 、last_name 、salary 和 department_id 信息。并按 salary 從大到小 (降序) 進(jìn)行排列。
SELECT employee_id, last_name, salary FROM employees ORDER BY salary DESC;
查詢結(jié)果:

二、 使用列的別名來排序
在SQL中,可以使用字段 (列) 的別名來進(jìn)行排序。因?yàn)橛袝r(shí)我們需要計(jì)算表中沒有的字段 (如年薪 annual_salary ) ,或者有些字段名字實(shí)在是太長了,使用簡短的別名可以提高我們編程的效率。如下例子所示:
【例子】查詢員工表 employees 中的員工的 employee_id 、last_name 、月薪 salary 和 年薪 annual_salary 信息。并按 annual_salary 從大到小 (降序) 進(jìn)行排列。
SELECT employee_id, last_name, salary, salary * (1 + IFNULL(commission_pct, 0) * 12) AS "annual_salary" FROM employees ORDER BY annual_salary DESC;
查詢結(jié)果:

【注意】
- 格式要求,
WHERE必須聲明在FROM后。 - 列的別名只能在
ORDER BY...中使用,不能在WHERE中使用。**如果在WHERE中使用列的別名,SQL會(huì)報(bào)錯(cuò)。那為什么MySQL中列的別名不能在WHERE中使用呢?原因如下:
【原因】
SELECT employee_id, last_name, department_id FROM employees WHERE department_id IN(50, 60, 70) ORDER BY department_id DESC;
- 在SQL中,查詢語句不是按照上述代碼從第1行到第4行從上往下執(zhí)行的。而是首先執(zhí)行第2行 FROM... ,先去找要查詢的表。
- 再執(zhí)行第3行 WHERE... ,去篩選符合條件的元組。
- 然后執(zhí)行第1行 SELECT... ,顯示你要查詢的字段。在這一步才會(huì)生成列的別名,自然無法提供給上一步的 WHERE 來使用。但是可以提供給下一步的 ORDER BY 來使用。
- 最后才是第4行 ORDER BY... ,按某列排序。這個(gè)時(shí)候可以使用列的別名來進(jìn)行排序。
查詢結(jié)果:

三、 二級(jí)排序
在現(xiàn)實(shí)生活中,我們有時(shí)候希望先按某個(gè)字段排序,再按另一個(gè)字段排序。在SQL中我們可以使用二級(jí)排序來實(shí)現(xiàn)。使用方法請看下面例子:
【例子1】查詢員工表 employees 中的員工的員工ID employee_id 、名字 last_name 、月薪 salary 和部門ID department_id 。并先按部門ID department_id 降序排列,再按 salary 從大到小 (降序) 進(jìn)行排列。
SELECT employee_id, last_name, salary, department_id FROM employees ORDER BY department_id DESC, salary DESC;
查詢結(jié)果:

依次類推,可以在 ORDER BY 后面加逗號(hào),來實(shí)現(xiàn)三級(jí)、四級(jí)…排序。
總結(jié)
到此這篇關(guān)于MySQL如何對數(shù)據(jù)進(jìn)行排序的文章就介紹到這了,更多相關(guān)MySQL數(shù)據(jù)排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql類似oracle rownum寫法實(shí)例詳解
在本篇文章里小編給大家分享的是關(guān)于mysql類似oracle rownum寫法以及相關(guān)實(shí)例內(nèi)容,需要的朋友們可以學(xué)習(xí)下。2019-09-09
deepin20.1系統(tǒng)安裝MySQL8.0.23(超詳細(xì)的MySQL8安裝教程)
這篇文章主要介紹了deepin20.1系統(tǒng)安裝MySQL8.0.23(最美國產(chǎn)Liunx系統(tǒng),最詳細(xì)的MySQL8安裝教程),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
MySQL數(shù)據(jù)庫設(shè)置遠(yuǎn)程訪問權(quán)限方法小結(jié)
很多情況下我們需要遠(yuǎn)程連接mysql數(shù)據(jù)庫,那么就可以參考下面的權(quán)限設(shè)置2013-10-10
坑人的Mysql5.7問題(默認(rèn)不支持Group By語句)
這篇文章主要介紹了坑人的Mysql5.7問題(默認(rèn)不支持Group By語句),具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
mysql處理海量數(shù)據(jù)時(shí)的一些優(yōu)化查詢速度方法
最近一段時(shí)間由于工作需要,開始關(guān)注針對Mysql數(shù)據(jù)庫的select查詢語句的相關(guān)優(yōu)化方法,需要的朋友可以參考下2017-04-04

