MySQL中的ORDER BY問題
MySQL中的ORDER BY?
當(dāng)我們使用SELECT語句查詢某個數(shù)據(jù)庫的單個列時,如果不排序,數(shù)據(jù)一般將以它在底層表中出現(xiàn)的順序顯示。
這可以是數(shù)據(jù)最初添加到表中的順序。
但是,如果數(shù)據(jù)后來進(jìn)行過更新或刪除,則此順序?qū)盏組ySQL重用回收存儲空間的影響。
因此,如果不明確控制的話,不能(也不應(yīng)該)依賴該排序順序。
關(guān)系數(shù)據(jù)庫設(shè)計理論認(rèn)為,如果不明確規(guī)定排序順序,則不應(yīng)該假定檢索出的數(shù)據(jù)的順序有意義。
?為了明確地排序用SELECT語句檢索出的數(shù)據(jù),可以使用ORDER BY子句。
ORDER BY子句取一個或多個列的名字,據(jù)此對輸出進(jìn)行排序。
假設(shè)我們有這樣的一張學(xué)生信息表如下
首先只用SELECT語句來查詢學(xué)生的年齡信息
我們可以看到,在沒有對檢索出的數(shù)據(jù)進(jìn)行排序的情況下,顯示的就是我們最初將數(shù)據(jù)添加到表中的順序。
我們使用ORDER BY子句對檢索的結(jié)果進(jìn)行排序
我們可以看到,檢索的結(jié)果進(jìn)行了一個升序的排序。
在默認(rèn)情況下ORDER BY對檢索的結(jié)果進(jìn)行升序(ASC)排序,我們也可以把它改為降序(DESC)排序:
但是,在大多數(shù)情況下我們需要按不止一個列進(jìn)行數(shù)據(jù)的排序,這時也可以使用ORDER BY子句進(jìn)行排序。
例如我們想要對學(xué)生先按班級排序
同一個班級中的學(xué)生再按年齡排序:
可以看到,檢索到的數(shù)據(jù)先按照班級升序?qū)W(xué)生進(jìn)行了排序,對于同一個班級的學(xué)生,按照年齡的升序再進(jìn)行排序。
同理,我們也可以先進(jìn)行班級的升序排序,再進(jìn)行年齡的降序排序:
綜上我們可以知道,ORDER BY子句可以對一個或多個列進(jìn)行升序或降序的排序,并且ASC和DESC只對直接位于它前面的列名起作用。
ORDER BY子句還可以和LIMIT一起使用,由此可以找出檢索結(jié)果中的最大值或者最小值。
比如我們可以找到所有學(xué)生中年齡最小的同學(xué)
注意:
在給出ORDER BY子句時,應(yīng)該保證它位于FROM子句之后。
如果使用LIMIT,那么LIMIT必須位于ORDER BY之后。
使用子句的次序不對將產(chǎn)生錯誤信息。那么LIMIT必須位于ORDER BY之后。
使用子句的次序不對將產(chǎn)生錯誤信息。
總結(jié)
?以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
mysql 終結(jié)點映射器中沒有更多的終結(jié)點可用的解決方法
在安裝MySQL的時候遇到“終結(jié)點映射器中沒有更多的終結(jié)點可用”提示2009-03-03MySQL刪除表數(shù)據(jù)、清空表命令詳解(truncate、drop、delete區(qū)別)
介紹了MySQL中清空或刪除表數(shù)據(jù)的三種方法:truncate、delete和drop,以及它們的特點、使用場景和注意事項,Truncate用于快速刪除表中所有數(shù)據(jù)并釋放空間,但不保留表結(jié)構(gòu);delete用于刪除表中特定行或所有數(shù)據(jù),保留表結(jié)構(gòu)且操作可回滾2024-10-10

mysql問題之slow log中出現(xiàn)大量的binlog dump記錄的解決方法