Я попытаюсь объяснить это лучше на другом вопросе. Это запрос, который, я думаю, должен работать, но, конечно, MySQL не поддерживает этот конкретный запрос на выборку:
select *
from articles a
where a.article_id in
(select f.article_id
from articles f
where f.category_id = a.category_id
order by f.is_sticky, f.published_at
limit 3) /* limit isn't allowed inside a IN subquery */
То, что я пытаюсь заархивировать, таково: в таблице статей у меня есть несколько статей для нескольких категорий. Мне нужно получить не более трех статей в каждой категории (любое количество категорий).
Вот данные:
CREATE TABLE articles (
article_id int(10) unsigned NOT NULL AUTO_INCREMENT,
category_id int(10) unsigned NOT NULL,
title varchar(100) NOT NULL,
is_sticky boolean NOT NULL DEFAULT 0,
published_at datetime NOT NULL,
PRIMARY KEY (article_id)
);
INSERT INTO articles VALUES
(1, 1, 'foo', 0, '2009-02-06'),
(1, 1, 'bar', 0, '2009-02-07'),
(1, 1, 'baz', 0, '2009-02-08'),
(1, 1, 'qox', 1, '2009-02-09'),
(1, 2, 'foo', 0, '2009-02-06'),
(1, 2, 'bar', 0, '2009-02-07'),
(1, 2, 'baz', 0, '2009-02-08'),
(1, 2, 'qox', 1, '2009-02-09');
Я пытаюсь найти следующее:
1, 1, qox, 1, 2009-02-09
1, 1, foo, 0, 2009-02-06
1, 1, bar, 0, 2009-02-07
1, 2, qox, 1, 2009-02-09
1, 2, foo, 0, 2009-02-06
1, 2, bar, 0, 2009-02-07
Обратите внимание, как 'quox' поднялся на первое место в своей категории, потому что он липкий.
Можете ли вы найти способ избежать LIMIT внутри подзапроса?
Спасибо