V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
refresh
V2EX  ›  问与答

求一个查询最低价的 sql

  •  
  •   refresh · 2014-09-04 19:48:47 +08:00 · 3040 次点击
    这是一个创建于 3734 天前的主题,其中的信息可能已经有所发展或是发生改变。
    表是这样的:product_id(产品id),price(价格), seller_id(商家id),area_id(所在区域)
    现在需要查到,每个产品,每个区域的最低价格以及这个价格所对应的商家。
    3 条回复    2014-09-05 10:03:36 +08:00
    feiyuanqiu
        1
    feiyuanqiu  
       2014-09-04 20:11:00 +08:00   ❤️ 1
    表应该还有个主键吧...试了一下,用了子查询,性能有问题...坐等其他大大的方法

    SELECT
    a.*
    FROM
    test_2 a
    JOIN
    (SELECT
    area_id, product_id, MIN(price) AS price
    FROM
    test_2
    GROUP BY area_id, product_id) b
    ON a.`area_id` = b.area_id
    AND a.`product_id` = b.product_id
    AND a.`price` = b.price
    refresh
        2
    refresh  
    OP
       2014-09-04 20:32:16 +08:00
    @feiyuanqiu 不一定会有主键,实际上这几个字段并不是同一个表中出来的,但主键对这个查询应该没有影响吧。
    fengchang
        3
    fengchang  
       2014-09-05 10:03:36 +08:00
    如果要查出该价格对应的seller_id,子查询应该是难免的,除了1楼提供的方法,还可以

    SELECT * FROM product
    WHERE (product_id,area_id,price) IN
    (
    SELECT product_id, area_id, MIN(price) price FROM product
    GROUP BY product_id, area_id
    );

    但是性能不如1楼
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2830 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 11:53 · PVG 19:53 · LAX 03:53 · JFK 06:53
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.