MySQL多字段條件排序?MySQL order by降序升序查詢語句/函數

MySQL的多字段條件排序?MySQL的 order by降序升序查詢語句/函數

MySQL 排序

我們知道從MySQL 表中使用SQL SELECT 語句來讀取數據。

如果我們需要對讀取的數據進行排序,我們就可以使用MySQL 的 訂購 子句來設定你想按哪個字段哪種方式來進行排序,再返回搜索結果。

語法

以下是SQL SELECT 語句使用ORDER BY 子句將查詢數據排序後再返回數據:

SELECT field1, field2,...fieldN table_name1, table_name2...
ORDER BY field1, [field2...] [ASC [DESC]]
  • 你可以使用任何字段來作為排序的條件,從而返回排序後的查詢結果。
  • 你可以設定多個字段來排序。
  • 你可以使用ASC 或DESC 關鍵字來設置查詢結果是按升序或降序排列。默認情況下,它是按升序排列。
  • 你可以添加WHERE…LIKE 子句來設置條件。

在命令提示符中使用ORDER BY 子句

以下將在SQL SELECT 語句中使用ORDER BY 子句來讀取MySQL 數據表chenweiliang_tbl 中的數據:

實例

嘗試以下實例,結果將按升序及降序排列。

SQL 排序

mysql> use chenweiliang;
Database changed
mysql> SELECT * from chenweiliang_tbl ORDER BY submission_date ASC;
+-----------+---------------+---------------+-----------------+
| chenweiliang_id | chenweiliang_title | chenweiliang_author | submission_date |
+-----------+---------------+---------------+-----------------+
| 3 | 学习 Java | chenweiliang.com | 2015-05-01 |
| 4 | 学习 Python | chenweiliang.com | 2016-03-06 |
| 1 | 学习 PHP | 陈沩亮博客 | 2017-04-12 |
| 2 | 学习 MySQL | 陈沩亮博客 | 2017-04-12 |
+-----------+---------------+---------------+-----------------+
4 rows in set (0.01 sec)
 
mysql> SELECT * from chenweiliang_tbl ORDER BY submission_date DESC;
+-----------+---------------+---------------+-----------------+
| chenweiliang_id | chenweiliang_title | chenweiliang_author | submission_date |
+-----------+---------------+---------------+-----------------+
| 1 | 学习 PHP | 陈沩亮博客 | 2017-04-12 |
| 2 | 学习 MySQL | 陈沩亮博客 | 2017-04-12 |
| 4 | 学习 Python | chenweiliang.com | 2016-03-06 |
| 3 | 学习 Java | chenweiliang.com | 2015-05-01 |
+-----------+---------------+---------------+-----------------+
4 rows in set (0.01 sec)

讀取chenweiliang_tbl 表中所有數據並按submission_date 字段的升序排列。


在PHP 腳本中使用ORDER BY 子句

你可以使用PHP函數的mysqli_query() 及相同的SQL SELECT 帶上ORDER BY 子句的命令來獲取數據。

該函數用於執行SQL 命令,然後通過PHP 函數mysqli_fetch_array() 來輸出所有查詢的數據。

實例

嘗試以下實例,查詢後的數據按submission_date 字段的降序排列後返回。

MySQL ORDER BY 測試:

<?
php
$dbhost = 'localhost:3306'; // mysql服务器主机地址
$dbuser = 'root'; // mysql用户名
$dbpass = '123456'; // mysql用户名密码
$conn = mysqli_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
 die('连接失败: ' . mysqli_error($conn));
}
// 设置编码,防止中文乱码
mysqli_query($conn , "set names utf8");
 
$sql = 'SELECT chenweiliang_id, chenweiliang_title, 
 chenweiliang_author, submission_date
 FROM chenweiliang_tbl
 ORDER BY submission_date ASC';
 
mysqli_select_db( $conn, 'chenweiliang' );
$retval = mysqli_query( $conn, $sql );
if(! $retval )
{
 die('无法读取数据: ' . mysqli_error($conn));
}
echo '<h2>陈沩亮博客 MySQL ORDER BY 测试<h2>';
echo '<table border="1"><tr><td>教程 ID</td><td>标题</td><td>作者</td><td>提交日期</td></tr>';
while($row = mysqli_fetch_array($retval, MYSQL_ASSOC))
{
 echo "<tr><td> {$row['chenweiliang_id']}</td> ".
 "<td>{$row['chenweiliang_title']} </td> ".
 "<td>{$row['chenweiliang_author']} </td> ".
 "<td>{$row['submission_date']} </td> ".
 "</tr>";
}
echo '</table>';
mysqli_close($conn);
?>

希望陳溈亮博客( https://www.chenweiliang.com/ ) 分享的《MySQL多字段條件排序?MySQL order by降序升序查詢語句/函數》,對您有幫助。

歡迎分享本文鏈接:https://www.chenweiliang.com/cwl-476.html

歡迎加入陳溈亮博客的Telegram 頻道,獲取最新更新!

🔔 率先在頻道置頂目錄獲取寶貴的《ChatGPT 內容行銷AI 工具使用指南》! 🌟
📚 這份指南蘊含價值巨大,🌟難逢的機遇,切勿錯失良機! ⏰⌛💨
喜歡就分享和按贊!
您的分享和按贊,是我們持續的動力!

 

發表評論

您的電子郵箱地址不會被公開。 必填項已用 * 標註

滾動到頂部