3.6.2保存某列最大值的行

 

任务:查找最昂贵商品的数量,经销商和价格。

这可以通过子查询轻松完成:

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

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

其他解决方案是使用LEFT JOIN或排序按价格降序的所有行,并使用特定于MySQL的LIMIT子句仅获取第一行

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

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

如果有几本最昂贵的文章,每本的价格为19.95,则LIMIT解决方案将仅显示其中一篇。

原文地址:https://www.cnblogs.com/owlin/p/13730966.html