每组最大N和填充

时间:2012-10-29 14:08:19

标签: sql sqlite aggregate-functions greatest-n-per-group

我一直试图在周末解决这个问题,到目前为止没有运气。我有两张桌子:

TopOffers:

OfferId    RetailerId      Order
1          38              0
2          8               3
3          17              2
4          22              1

Offers:

Id     RetailerId       Name            Description          etc...
1      3                Strawberry      Red and smelly
2      38               Cookie          Crunchy
3      17               Onion           Of the nice kind
4      22               Apple           Cheap
5      8                Toothbrush      Lasts extra long!

我的目标是获得每个零售商ID的前10个优惠。它们应列出的顺序由TopOffer表中的Order字段指定(排序顺序为升序)。最重要的是,当零售商的TopOffer记录少于10时,结果应填充到10个报价。 TopOffer表每个零售商总是包含10个或更少的记录。

到目前为止,我已经成功实现这一目标,这有效(我意识到它没有获得前10名,而是TopOffer表中的所有内容,这是好的,因为TopOffer表总是等于或者小于任何零售商的前10名):

SELECT b.*
FROM
(
    SELECT o.Id, to.`Order` FROM Offer AS o
    LEFT JOIN TopOffer AS to
    ON o.Id = to.OfferId
) AS a,
(
    SELECT o.*, to.`Order` FROM Offer AS o
    LEFT JOIN TopOffer AS to
    ON o.Id = to.OfferId
) AS b
WHERE a.`Order` >= b.`Order` AND a.Id = b.Id
GROUP BY b.RetailerId, b.Id
HAVING Count(1) BETWEEN 1 AND 10
ORDER BY RetailerId, `Order` ASC

不幸的是,如果该零售商没有10个TopOffer记录,我似乎无法找到任何填充此查询结果的方法,其中包含TopOffer表中没有条目的商品。

我最诚挚地感谢您提供任何帮助!

1 个答案:

答案 0 :(得分:0)

如果你创建一个数字为1-10的虚拟表,你可以加入你的结果以获得10个

   select number, results.*
   from
       (select 1 as number union select 2 union select 3 ... union select 10) numbers
            left join
       (your query here) results
            on numbers.number = results.rank