3.6.2 包含某一行最大值的记录

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

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

  1. SELECT article, dealer, price
  2. FROM shop
  3. WHERE price=(SELECT MAX(price) FROM shop);
  4. +---------+--------+-------+
  5. | article | dealer | price |
  6. +---------+--------+-------+
  7. | 0004 | D | 19.95 |
  8. +---------+--------+-------+

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

  1. SELECT s1.article, s1.dealer, s1.price
  2. FROM shop s1
  3. LEFT JOIN shop s2 ON s1.price < s2.price
  4. WHERE s2.article IS NULL;
  5. SELECT article, dealer, price
  6. FROM shop
  7. ORDER BY price DESC
  8. LIMIT 1;

注意

如果有几件最贵的商品, 它们的价格都是 19.95, LIMIT 子句只会显示它们当中的一条.