Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Казалось бы простейший запрос, но...

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: Запрос к базе mySql на котором уже зубы сломали
alfavir
Отправлено: 24 Января, 2017 - 14:34:09
Post Id


Новичок


Покинул форум
Сообщений всего: 2
Дата рег-ции: Янв. 2017  


Помог: 0 раз(а)




Здравствуйте, коллеги.

Сегодняшний день преподнес мне сюрприз: на казалось бы тривиальной задаче с напарником сломали зуб. Итак:

Имеем 2 таблицы (приведу только значимые поля)

product
======================
| uid | description | brand_uid |
======================

brand
=============
| uid | description |
=============

Привязка brand.uid = product.brand_uid

Задача: вывести рандомно по 4 продукта каждого бренда. Рандомная сортировка относится как к бренду так и к продукту.
Просто? Целый день не можем найти решение на MySql.
Буду признателен за элегантный запрос.

(Отредактировано автором: 24 Января, 2017 - 14:41:02)

 
 Top
Sail
Отправлено: 24 Января, 2017 - 16:21:56
Post Id



Участник


Покинул форум
Сообщений всего: 1131
Дата рег-ции: Февр. 2014  


Помог: 57 раз(а)




 
 Top
Мелкий Супермодератор
Отправлено: 24 Января, 2017 - 16:22:11
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




А нет у mysql элегантного решения.
Вообще нужен topN для группы: http://www[dot]sql[dot]ru/forum/actualut[dot][dot][dot]&msg=7489069
Сбоку прикрутить получение случайных N вместо topN... Короче штука медлительная будет.


-----
PostgreSQL DBA
 
 Top
alfavir
Отправлено: 24 Января, 2017 - 17:36:44
Post Id


Новичок


Покинул форум
Сообщений всего: 2
Дата рег-ции: Янв. 2017  


Помог: 0 раз(а)




Sail пишет:


Огромное спасибо. Положу в копилку сегодняшних методов.

По примеру статьи сделал так (здесь реальные имена таблиц и полей):

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() то получится тот же самый результат, но вразброс. То есть элементы продукции те же самые...
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB