今天在使用ORDER BY的過程中出現了一點問題,發現之前對ORDER BY理解是錯誤的。
之前在w3s網站上看到ORDER BY的用法,以為是對選出來的數據按關鍵字升序或者降序排列,結果今天嘗試select數據集數據的時候,發現使用ORDER BY 和ORDER BY DESC得出的查詢結果完全不一樣,按照自己之前的理解它們應該是結果相同,而內部順序不一樣而已。
問了一下同事,查了一下文檔,才恍然大悟。如果我們在執行select語句的時候使用ORDER BY (DESC),那麼它首先會對所有記錄按照關鍵字有一個排序,然後依次讀取所需的記錄,而不是先選出記錄再進行降序排列。 一個概念性的錯誤,所以記下來警示自己。
MySQL Order By keyword是用來給記錄中的數據進行分類的。
MySQL Order By Keyword根據關鍵詞分類
ORDER BY keyword是用來給記錄中的數據進行分類的。
MySQL Order By語法
復制代碼 代碼如下:
SELECT column_name(s)
FROM table_name
ORDER BY column_name
注意:SQL語句是“字母大小寫不敏感”的語句(它不區分字母的大小寫),即:“ORDER BY”和“order by”是一樣的。
MySQL Order By案例
下面的例子:從“Person”表中選取所有記錄,並將“Age”列進行分類:
復制代碼 代碼如下:
<?php
$con = mysql_connect("localhost","peter","abc123");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("my_db", $con);
$result = mysql_query("SELECT * FROM person ORDER BY age");
while($row = mysql_fetch_array($result))
{
echo $row['FirstName']
echo " " . $row['LastName'];
echo " " . $row['Age'];
echo "<br />";
}
mysql_close($con);
?>
[html]
上面的代碼將輸出下面的結果:
Glenn Quagmire 33
Peter Griffin 35
按照升序或者降序進行分類排列
如果你使用了“ORDER BY”關鍵詞,所有記錄將按照默認的升序進行排列(即:從1到9,從a到z)
使用“DESC”關鍵詞可以制定所有的數據按照降序排列(即:從9到1,從z到a):
[code]
SELECT column_name(s)
FROM table_name
ORDER BY column_name DESC
MySQL Order By根據兩列進行分類
很多時候,我們需要同時根據兩列內容(或者更多列)來對數據進行分類。當指定的列數多於一列時,僅在第一列的值完全相同時才參考第二列:
復制代碼 代碼如下:
SELECT column_name(s)
FROM table_name
ORDER BY column_name1, column_name2