相關文件 下載本手冊
PDF (US Ltr) - 39.9Mb
PDF (A4) - 40.0Mb
Man Pages (TGZ) - 258.5Kb
Man Pages (Zip) - 365.5Kb
Info (Gzip) - 4.0Mb
Info (Zip) - 4.0Mb


MySQL 8.4 參考手冊  /  ...  /  找出特定欄位最大值的資料列

5.6.2 找出特定欄位最大值的資料列

任務:找出最貴的文章的編號、經銷商和價格。

這可以很容易地使用子查詢完成

SELECT article, dealer, price
FROM   shop
WHERE  price=(SELECT MAX(price) FROM shop);

+---------+--------+-------+
| article | dealer | price |
+---------+--------+-------+
|    0004 | D      | 19.95 |
+---------+--------+-------+

另一個解決方案是使用 LEFT JOIN,如下所示

SELECT s1.article, s1.dealer, s1.price
FROM shop s1
LEFT JOIN shop s2 ON s1.price < s2.price
WHERE s2.article IS NULL;

您也可以通過按價格降序排序所有資料列,並使用 MySQL 特有的 LIMIT 子句僅取得第一列來完成此操作,如下所示

SELECT article, dealer, price
FROM shop
ORDER BY price DESC
LIMIT 1;
注意

如果有幾個最貴的文章,每個價格都是 19.95,LIMIT 解決方案只會顯示其中一個。