Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Как извлечь 3 случайные записи из разных категорий?
 
 автор: antf   (28.04.2011 в 20:29)   письмо автору
 
 

Здравствуйте.
Есть таблица услуг конторы. У нее поля: id, title, id_cat. Как сделать так, чтобы на главной выводилось 3 случайных услуги каждой категории? Можно ли решить задачу одним sql-запросом?

  Ответить  
 
 автор: antf   (28.04.2011 в 20:33)   письмо автору
 
   для: antf   (28.04.2011 в 20:29)
 

Мне ничего не приходит в голову, кроме:


(SELECT title FROM services WHERE id_cat = 1 ORDER BY RAND() LIMIT 1)
UNION
(SELECT title FROM services WHERE id_cat = 2 ORDER BY RAND() LIMIT 1)
UNION
(SELECT title FROM services WHERE id_cat = 3 ORDER BY RAND() LIMIT 1)

  Ответить  
 
 автор: cheops   (28.04.2011 в 20:50)   письмо автору
 
   для: antf   (28.04.2011 в 20:33)
 

А так все-таки нужна одна ссылка на раздел, а не три (как я сначала подумал)? Тогда можно поступить так
SELECT
  res.id AS id,
  res.title AS title,
  res.id_cat AS id_cat
FROM
  (SELECT id_cat FROM tbl GROUP BY id_cat) AS cat
LEFT JOIN
  tbl AS res
ON
  cat.id_cat = res.id_cat
GROUP BY cat.id_cat
ORDER BY RAND()

  Ответить  
 
 автор: antf   (28.04.2011 в 21:03)   письмо автору
 
   для: cheops   (28.04.2011 в 20:50)
 

Этот запрос выводит 3 одинаковых услуги из каждой категории, порядок каждый раз меняется.
Надо выводить по 1 случайной услуге из каждой категории, причем с сортировкой по id_cat.

PS Вариант UNION как раз для этого подходит, я думал, что попроще есть :)

  Ответить  
 
 автор: cheops   (28.04.2011 в 21:13)   письмо автору
 
   для: antf   (28.04.2011 в 21:03)
 

Да есть такое дело, нужно модифицировать вторую таблицу
SELECT 
  res.id AS id, 
  res.title AS title, 
  res.id_cat AS id_cat 
FROM 
  (SELECT id_cat FROM tbl GROUP BY id_cat) AS cat 
LEFT JOIN 
  (SELECT * FROM tbl ORDER BY RAND()) AS res 
ON 
  cat.id_cat = res.id_cat 
GROUP BY cat.id_cat 

  Ответить  
 
 автор: antf   (28.04.2011 в 21:28)   письмо автору
 
   для: cheops   (28.04.2011 в 21:13)
 

Работает. А какой вариант будет быстрее этот или с UNION?

  Ответить  
 
 автор: cheops   (28.04.2011 в 21:39)   письмо автору
 
   для: antf   (28.04.2011 в 21:28)
 

Сложно сказать (от размера таблиц и буферов зависит), таблица вероятно не очень большая, думаю оба запроса будет примерно одинаково выполняться (у меня по крайне мере на моему куцем дампе разницы никакой нет).

PS В последнем запросе единственное удобство, он от номеров не зависит, т.е. если нумерация разделов у вас начнется с 5, 6, 7, и т.д. он будет работать и с ними, а первый запрос с UNION потребуется отредактировать. Правда первый запрос при увеличении дампа и хорошем буфере для сортировки и выборке случайных значений теоретически должен работать быстрее.

  Ответить  
 
 автор: cheops   (28.04.2011 в 20:41)   письмо автору
 
   для: antf   (28.04.2011 в 20:29)
 

Количество категорий id_cat произвольно и заранее не определено? Тогда вряд ли тут удасться оботись каким-то элегантным запросом, без привлечения клиентского кода.

  Ответить  
 
 автор: antf   (28.04.2011 в 20:45)   письмо автору
 
   для: cheops   (28.04.2011 в 20:41)
 

>Количество категорий id_cat произвольно и заранее не определено?

Всегда 3

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования