MySQL 9.0 版本說明
任務:找出最貴商品的編號、經銷商和價格。
這可以很輕鬆地使用子查詢完成
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
解決方案只會顯示其中一個。