3

我正在考虑如何编写此查询。我认为这可能涉及在 ORDER BY 声明中包含一个 CASE,但我可以使用一些指导。

我有两列数据;身份证和价格。当我按价格 ASC 订购时,我的查询结果显示如下:

身份证 | 价格
3 | 150
1 | 200
3 | 205
2 | 210
2 | 230
3 | 270
1 | 300
2 | 340
3 | 500

我要做的是仍然按价格 ASC 订购,但略有不同。我也想按 ID 分组。例如,我希望查询查找所有结果中的最低价格,然后查找具有相同 ID 的所有其他记录,按价格 ASC 顺序列出。找到该 ID 的所有记录后,查询将查找所有其他剩余记录,再次找到最低价格,然后重复。因此,每次经过此循环时,结果池都会减少。对于上面的示例,结果将是:

身份证 | 价格
3 | 150
3 | 205
3 | 270
3 | 500
1 | 200
1 | 300
2 | 210
2 | 230
2 | 340

该循环类似于查找最低价格,查找具有相同 ID 的所有记录并按价格顺序列出,查找剩余结果的最低价格,查找具有相同 ID 的所有记录并按价格顺序列出,重复......

有任何想法吗?如果我解释得不够好,请告诉我。

4

3 回答 3

5
SELECT ID, PRICE
FROM t
ORDER BY MIN(PRICE) OVER (PARTITION BY ID), PRICE

SQL小提琴

于 2013-03-05T02:05:22.487 回答
3

您正在使用 Postgres,因此您具有窗口功能。这是您需要的 SQL 示例:

select id, price
from (select t.*,
             min(price) over (partition by id) as minprice
      from t
     ) t
order by minprice, id, price
于 2013-03-05T01:23:46.730 回答
2

SQL小提琴

select t.id, t.price
from
    t
    inner
    join (
        select row_number() over(order by price) o, id
        from (
            select id, min(price) price
            from t
            group by id
        ) s
    ) s on s.id = t.id
order by s.o, t.price
于 2013-03-05T01:54:25.493 回答