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 解决方案将仅显示其中一个。