相关文档 下载本手册
PDF (US Ltr) - 40.0Mb
PDF (A4) - 40.1Mb
Man Pages (TGZ) - 258.2Kb
Man Pages (Zip) - 365.3Kb
Info (Gzip) - 4.0Mb
Info (Zip) - 4.0Mb


MySQL 9.0 参考手册  /  ...  /  查找特定列最大值所在的行

5.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 | +---------+--------+-------+

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