周末我一直在尝试解决这个问题,到目前为止还没有运气。我有两张桌子:
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 个优惠。它们的列出顺序由Order
TopOffer 表中的字段指定(排序顺序为升序)。最重要的是,当零售商的 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 表中没有条目。
我最诚挚的感谢您的帮助!