Учитывая отношение m2m: элементы-категории У меня есть три таблицы:
- элементы,
- категории и
- items_categories, которые содержат ссылки на
Я хочу найти элемент из всех заданных категорий:
Find Item
belonging to a category in [1,3,6]
and belonging to a category in [7,8,4]
and belonging to a category in [12,66,42]
and ...
Есть два способа, которые я могу придумать для выполнения этого в mySQL.
ВАРИАНТ A: INNER JOIN:
SELECT id from items
INNER JOIN category c1 ON (item.id = c1.item_id)
INNER JOIN category c2 ON (item.id = c2.item_id)
INNER JOIN category c3 ON (item.id = c3.item_id)
...
WHERE
c1.category_id IN [1,3,6] AND
c2.category_id IN [7,8,4] AND
c3.category_id IN [12,66,42] AND
...;
ВАРИАНТ B: СУЩЕСТВУЕТ:
SELECT id from items
WHERE
EXISTS(SELECT category_id FROM category WHERE category.item_id = id AND category_id in [1,3,6] AND
EXISTS(SELECT category_id FROM category WHERE category.item_id = id AND category_id in [7,8,4] AND
EXISTS(SELECT category_id FROM category WHERE category.item_id = id AND category_id in [12,66,42] AND
...;
Оба варианта работают. Вопрос: Какой самый быстрый/самый оптимальный для большой таблицы элементов? Или есть ОПЦИЯ C Я не хватает?