首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >具有填充的每组最大N

具有填充的每组最大N
EN

Stack Overflow用户
提问于 2012-10-29 22:08:19
回答 1查看 154关注 0票数 1

上周末,我一直在尝试解决这个问题,但到目前为止还没有成功。我有两张表:

TopOffers:

代码语言:javascript
复制
OfferId    RetailerId      Order
1          38              0
2          8               3
3          17              2
4          22              1

Offers:

代码语言:javascript
复制
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名):

代码语言:javascript
复制
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表中没有条目的优惠来填充这个查询的结果。

对您的帮助,我致以最诚挚的感谢!

EN

回答 1

Stack Overflow用户

发布于 2012-10-29 22:17:17

如果您创建了一个数字为1-10的虚拟表,则可以对结果进行左连接,以获得每个表中的10个

代码语言:javascript
复制
   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
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13123243

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档