refresh
V2EX  ›  问与答

求一个查询最低价的 sql

  •  
  •   refresh · Sep 4, 2014 · 3544 views
    This topic created in 4308 days ago, the information mentioned may be changed or developed.
    表是这样的:product_id(产品id),price(价格), seller_id(商家id),area_id(所在区域)
    现在需要查到,每个产品,每个区域的最低价格以及这个价格所对应的商家。
    3 replies    2014-09-05 10:03:36 +08:00
    feiyuanqiu
        1
    feiyuanqiu  
       Sep 4, 2014   ❤️ 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
       Sep 4, 2014
    @feiyuanqiu 不一定会有主键,实际上这几个字段并不是同一个表中出来的,但主键对这个查询应该没有影响吧。
    fengchang
        3
    fengchang  
       Sep 5, 2014
    如果要查出该价格对应的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楼
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2717 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 36ms · UTC 12:53 · PVG 20:53 · LAX 05:53 · JFK 08:53
    ♥ Do have faith in what you're doing.