MySQL 8.0 参考手册  / 第 3 章教程  / 3.6 常见查询示例  /  3.6.2 某列最大值所在的行

3.6.2 某列最大值所在的行

任务:找出最贵商品的编号、经销商和价格。

这很容易通过子查询完成:

Press CTRL+C to copy
SELECT article, dealer, price FROM shop WHERE price=(SELECT MAX(price) FROM shop); +---------+--------+-------+ | article | dealer | price | +---------+--------+-------+ | 0004 | D | 19.95 | +---------+--------+-------+

另一种解决方案是使用 a LEFT JOIN,如下所示:

Press CTRL+C to copy
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子句仅获取第一行来执行此操作,如下所示:

Press CTRL+C to copy
SELECT article, dealer, price FROM shop ORDER BY price DESC LIMIT 1;
笔记

如果有几件最贵的商品,每件价格为 19.95,则LIMIT解决方案将只显示其中一件。