• 跳至主要導覽
  • 跳至主要內容
  • 跳至主要資訊欄
Office 指南

Office 指南

辦公室工作實用教學

  • Excel
  • Word
  • PowerPoint
  • Windows
  • PowerShell
  • R

MySQL/MariaDB 資料庫 ORDER BY 排序查詢結果教學與範例

介紹如何在 MySQL/MariaDB 資料庫中使用 ORDER BY 排序 SELECT 的查詢結果。

建立示範用資料

首先建立一張 person 資料表,並且插入了一些資料:

-- 建立 persons 資料表
CREATE TABLE persons (
  id INT NOT NULL AUTO_INCREMENT,              -- 序號,整數、非空、自動遞增
  name VARCHAR(255),                           -- 名字,可變長度的文字
  age INT UNSIGNED,                            -- 年齡,非負整數
  city ENUM('Taipei', 'Hsinchu', 'Kaohsiung'), -- 所在城市,固定選項
  PRIMARY KEY (id)                             -- 主鍵
);
-- 插入多筆資料至 persons 資料表
INSERT INTO persons (name, age, city) VALUES
  ("Hill", 21, "Kaohsiung"),
  ("Bond", 34, "Taipei"),
  ("Arden", 32, "Taipei"),
  ("Cole", 12, "Hsinchu"),
  ("Bell", 16, "Kaohsiung"),
  ("Dana", 19, "Hsinchu");
-- 查看 persons 資料表內所有資料
SELECT * FROM persons;
+----+-------+------+-----------+
| id | name  | age  | city      |
+----+-------+------+-----------+
|  1 | Hill  |   21 | Kaohsiung |
|  2 | Bond  |   34 | Taipei    |
|  3 | Arden |   32 | Taipei    |
|  4 | Cole  |   12 | Hsinchu   |
|  5 | Bell  |   16 | Kaohsiung |
|  6 | Dana  |   19 | Hsinchu   |
+----+-------+------+-----------+

排序查詢結果

依照 age 排序結果:

-- 以 age 排序
SELECT * FROM persons ORDER BY age;
+----+-------+------+-----------+
| id | name  | age  | city      |
+----+-------+------+-----------+
|  4 | Cole  |   12 | Hsinchu   |
|  5 | Bell  |   16 | Kaohsiung |
|  6 | Dana  |   19 | Hsinchu   |
|  1 | Hill  |   21 | Kaohsiung |
|  3 | Arden |   32 | Taipei    |
|  2 | Bond  |   34 | Taipei    |
+----+-------+------+-----------+

反向排序

若要反向排序,可在 ORDER BY 條件後方加上 DESC:

-- 以 age 反向排序
SELECT * FROM persons ORDER BY age DESC;
+----+-------+------+-----------+
| id | name  | age  | city      |
+----+-------+------+-----------+
|  2 | Bond  |   34 | Taipei    |
|  3 | Arden |   32 | Taipei    |
|  1 | Hill  |   21 | Kaohsiung |
|  6 | Dana  |   19 | Hsinchu   |
|  5 | Bell  |   16 | Kaohsiung |
|  4 | Cole  |   12 | Hsinchu   |
+----+-------+------+-----------+

多條件排序

若想要依照多個條件進行排序,可以用逗號分隔各個條件,排在前面的條件會被優先使用,例如先以 city 反向排序,再以 age 正向排序:

-- 先以 city 反向排序,再以 age 正向排序
SELECT * FROM persons ORDER BY city DESC, age;
+----+-------+------+-----------+
| id | name  | age  | city      |
+----+-------+------+-----------+
|  5 | Bell  |   16 | Kaohsiung |
|  1 | Hill  |   21 | Kaohsiung |
|  4 | Cole  |   12 | Hsinchu   |
|  6 | Dana  |   19 | Hsinchu   |
|  3 | Arden |   32 | Taipei    |
|  2 | Bond  |   34 | Taipei    |
+----+-------+------+-----------+

自訂順序

當我們根據 ENUM 的資料進行排序時,會以該 ENUM 欄位定義時的順序為準,如果想要改變這個順序,可以使用 FIELD 自訂元素的順序:

-- 先以 city 自訂排序,再以 age 正向排序
SELECT * FROM persons ORDER BY
  FIELD(city, "Hsinchu", "Kaohsiung", "Taipei"), age;
+----+-------+------+-----------+
| id | name  | age  | city      |
+----+-------+------+-----------+
|  4 | Cole  |   12 | Hsinchu   |
|  6 | Dana  |   19 | Hsinchu   |
|  5 | Bell  |   16 | Kaohsiung |
|  1 | Hill  |   21 | Kaohsiung |
|  3 | Arden |   32 | Taipei    |
|  2 | Bond  |   34 | Taipei    |
+----+-------+------+-----------+

參考資料:MySQL Tutorial

分類:資料庫 標籤:MySQL/MariaDB

讀者互動方式

發佈留言 取消回覆

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *

主要資訊欄

搜尋

近期文章

  • wrk:HTTP 網頁伺服器效能測試工具使用教學
  • C++ 語言使用 Crypto++ 實作 RSA 數位簽章教學與範例
  • C++ 語言使用 Crypto++ 實作 RSA-OAEP 搭配 SHA256 加密教學與範例
  • C++ 語言使用 Crypto++ 實作 AES 加密、解密、認證加密教學與範例
  • C++ 語言使用 Crypto++ 實作 MD5、SHA1、SHA2、BLAKE2 雜湊教學與範例
  • Ubuntu Linux 安裝、使用 Crypto++ 加密函式庫教學與範例
  • C 語言使用 OpenSSL 實作橢圓曲線 ECDH 金鑰交換教學與範例
  • Python 以 eciespy 實作 ECC 非對稱式加密方法教學與範例

推薦網站

  • Udemy 線上教學課程
  • Coursera 線上教學課程

關注本站

  • 電子郵件
  • Facebook

公益

  • 家扶基金會
  • 台灣世界展望會
  • Yahoo 奇摩公益
  • igiving 公益網
  • 兒福聯盟

Copyright © 2021 · Office Guide