MySQL 结果排序

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

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程