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

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

    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,如下所示:

    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;

    您还可以通过按价格降序对所有行进行排序并使用 MySQL 特定的 LIMIT 子句仅获取第一行来做到这一点,如下所示:

    1. SELECT article, dealer, price
    2. FROM shop
    3. ORDER BY price DESC
    4. LIMIT 1;

    您还可以通过按价格降序对所有行进行排序并使用 MySQL 特定的 LIMIT 子句仅获取第一行来做到这一点,如下所示:

    1. SELECT article, dealer, price
    2. FROM shop
    3. ORDER BY price DESC
    4. LIMIT 1;

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