欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL中的ORDER BY問(wèn)題

 更新時(shí)間:2023年12月01日 15:05:15   作者:舉個(gè)栗子?  
這篇文章主要介紹了MySQL中的ORDER BY問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

MySQL中的ORDER BY?

當(dāng)我們使用SELECT語(yǔ)句查詢(xún)某個(gè)數(shù)據(jù)庫(kù)的單個(gè)列時(shí),如果不排序,數(shù)據(jù)一般將以它在底層表中出現(xiàn)的順序顯示。

這可以是數(shù)據(jù)最初添加到表中的順序。

但是,如果數(shù)據(jù)后來(lái)進(jìn)行過(guò)更新或刪除,則此順序?qū)?huì)收到MySQL重用回收存儲(chǔ)空間的影響。

因此,如果不明確控制的話,不能(也不應(yīng)該)依賴(lài)該排序順序。

關(guān)系數(shù)據(jù)庫(kù)設(shè)計(jì)理論認(rèn)為,如果不明確規(guī)定排序順序,則不應(yīng)該假定檢索出的數(shù)據(jù)的順序有意義。

?為了明確地排序用SELECT語(yǔ)句檢索出的數(shù)據(jù),可以使用ORDER BY子句。

ORDER BY子句取一個(gè)或多個(gè)列的名字,據(jù)此對(duì)輸出進(jìn)行排序。

假設(shè)我們有這樣的一張學(xué)生信息表如下

首先只用SELECT語(yǔ)句來(lái)查詢(xún)學(xué)生的年齡信息

我們可以看到,在沒(méi)有對(duì)檢索出的數(shù)據(jù)進(jìn)行排序的情況下,顯示的就是我們最初將數(shù)據(jù)添加到表中的順序。

我們使用ORDER BY子句對(duì)檢索的結(jié)果進(jìn)行排序

我們可以看到,檢索的結(jié)果進(jìn)行了一個(gè)升序的排序。

在默認(rèn)情況下ORDER BY對(duì)檢索的結(jié)果進(jìn)行升序(ASC)排序,我們也可以把它改為降序(DESC)排序:

但是,在大多數(shù)情況下我們需要按不止一個(gè)列進(jìn)行數(shù)據(jù)的排序,這時(shí)也可以使用ORDER BY子句進(jìn)行排序。

例如我們想要對(duì)學(xué)生先按班級(jí)排序

同一個(gè)班級(jí)中的學(xué)生再按年齡排序:

可以看到,檢索到的數(shù)據(jù)先按照班級(jí)升序?qū)W(xué)生進(jìn)行了排序,對(duì)于同一個(gè)班級(jí)的學(xué)生,按照年齡的升序再進(jìn)行排序。

同理,我們也可以先進(jìn)行班級(jí)的升序排序,再進(jìn)行年齡的降序排序:

綜上我們可以知道,ORDER BY子句可以對(duì)一個(gè)或多個(gè)列進(jìn)行升序或降序的排序,并且ASC和DESC只對(duì)直接位于它前面的列名起作用。

ORDER BY子句還可以和LIMIT一起使用,由此可以找出檢索結(jié)果中的最大值或者最小值。

比如我們可以找到所有學(xué)生中年齡最小的同學(xué)

注意:

在給出ORDER BY子句時(shí),應(yīng)該保證它位于FROM子句之后。

如果使用LIMIT,那么LIMIT必須位于ORDER BY之后。

使用子句的次序不對(duì)將產(chǎn)生錯(cuò)誤信息。那么LIMIT必須位于ORDER BY之后。

使用子句的次序不對(duì)將產(chǎn)生錯(cuò)誤信息。

總結(jié)

?以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

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

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

    今天在查看mysql中發(fā)現(xiàn)比較慢,然后我使用了slow log,發(fā)現(xiàn)出現(xiàn)了大量的binlog dump記錄,下面我來(lái)給大家整理一下這個(gè)問(wèn)題的解決辦法
    2013-09-09
  • 最新評(píng)論