MySQL 结果排序
我们已经看到了从MySQL表中获取数据的SQL SELECT 命令。当你选择行时,MySQL服务器可以以任何顺序返回它们,除非你给出了排序结果的方式。但是,你可以通过添加一个 ORDER BY 子句来对结果集进行排序,该子句指定你想要排序的列或列。
语法
以下代码块是SELECT命令的通用SQL语法,加上ORDER BY子句来对MySQL表中的数据进行排序。
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表中提取数据 – tutorials_tbl 。
示例
尝试以下示例,以升序返回结果。
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT * from tutorials_tbl ORDER BY tutorial_author ASC
+-------------+----------------+-----------------+-----------------+
| tutorial_id | tutorial_title | tutorial_author | submission_date |
+-------------+----------------+-----------------+-----------------+
| 2 | Learn MySQL | Abdul S | 2007-05-24 |
| 1 | Learn PHP | John Poul | 2007-05-24 |
| 3 | JAVA Tutorial | Sanjay | 2007-05-06 |
+-------------+----------------+-----------------+-----------------+
3 rows in set (0.42 sec)
mysql>
验证按升序列出的所有作者名称。
在PHP脚本中使用ORDER BY子句
PHP使用 mysqli query() 或 mysql_query() 函数从MySQL表中获取排序记录。此函数接受两个参数,并在成功时返回TRUE,失败时返回FALSE。
语法
$mysqli->query($sql,$resultmode)
序号 | 参数和描述 |
---|---|
1 | $sql 必需 – 从表中获取排序记录的SQL查询。 |
2 | $resultmode 可选 – 定义所需行为的常量MYSQLI_USE_RESULT或MYSQLI_STORE_RESULT。默认情况下,使用MYSQLI_STORE_RESULT。 |
示例
尝试以下示例以从表中获取排序记录 –
将以下示例复制并粘贴为 mysql_example.php –
<html>
<head>
<title>Sorting MySQL Table records</title>
</head>
<body>
<?php
dbhost = 'localhost';dbuser = 'root';
dbpass = 'root@123';dbname = 'TUTORIALS';
mysqli = new mysqli(dbhost, dbuser,dbpass, dbname);
if(mysqli->connect_errno ) {
printf("Connect failed: %s<br />", mysqli->connect_error);
exit();
}
printf('Connected successfully.<br />');sql = "SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl order by tutorial_title asc";
result =mysqli->query(sql);
if (result->num_rows > 0) {
while(row =result->fetch_assoc()) {
printf(
"Id: %s, Title: %s, Author: %s, Date: %d <br />",
row["tutorial_id"],row["tutorial_title"],
row["tutorial_author"],row["submission_date"]
);
}
} else {
printf('No record found.<br />');
}
mysqli_free_result(result);mysqli->close();
?>
</body>
</html>
输出
访问部署在Apache Web服务器上的mysql_example.php,并验证输出结果。
Connected successfully.
Id: 5, Title: Apache Tutorial, Author: Suresh, Date: 2021
Id: 2, Title: HTML Tutorial, Author: Mahesh, Date: 2021
Id: 1, Title: MySQL Tutorial, Author: Mahesh, Date: 2021
Id: 3, Title: PHP Tutorial, Author: Mahesh, Date: 2021