Здравствуйте, коллеги.
Сегодняшний день преподнес мне сюрприз: на казалось бы тривиальной задаче с напарником сломали зуб. Итак:
Имеем 2 таблицы (приведу только значимые поля)
product
======================
| uid | description | brand_uid |
======================
brand
=============
| uid | description |
=============
Привязка brand.uid = product.brand_uid
Задача: вывести рандомно по 4 продукта каждого бренда. Рандомная сортировка относится как к бренду так и к продукту.
Просто? Целый день не можем найти решение на MySql.
Буду признателен за элегантный запрос.
1. alfavir - 24 Января, 2017 - 14:34:09 - перейти к сообщению
2. Sail - 24 Января, 2017 - 16:21:56 - перейти к сообщению
alfavir, есть статейка: Как вывести по N строк из каждой группы?
3. Мелкий - 24 Января, 2017 - 16:22:11 - перейти к сообщению
А нет у mysql элегантного решения.
Вообще нужен topN для группы: http://www[dot]sql[dot]ru/forum/actualut[dot][dot][dot]&msg=7489069
Сбоку прикрутить получение случайных N вместо topN... Короче штука медлительная будет.
Вообще нужен topN для группы: http://www[dot]sql[dot]ru/forum/actualut[dot][dot][dot]&msg=7489069
Сбоку прикрутить получение случайных N вместо topN... Короче штука медлительная будет.
4. alfavir - 24 Января, 2017 - 17:36:44 - перейти к сообщению
Sail пишет:
alfavir, есть статейка: Как вывести по N строк из каждой группы?
Огромное спасибо. Положу в копилку сегодняшних методов.
По примеру статьи сделал так (здесь реальные имена таблиц и полей):
SELECT
brand.description,
Pr1.*,
COUNT(*) num
FROM wt_spr_product Pr1
JOIN wt_spr_product Pr2
ON (Pr1.brand_uid = Pr2.brand_uid AND Pr1.id >= Pr2.id)
LEFT JOIN wt_spr_brand AS brand
ON brand.uid = Pr1.brand_uid
WHERE (Pr1.is_folder = 0 AND Pr1.visible = 1)
GROUP BY Pr1.brand_uid, Pr1.id
HAVING num <= 4
ORDER BY brand.description ASC, Pr1.description ASC
И вроде бы все неплохо, но нет рандома, а если его добавить в ORDER BY RAND() то получится тот же самый результат, но вразброс. То есть элементы продукции те же самые...