Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
1 / 1 / 1
Регистрация: 28.11.2013
Сообщений: 36

Выбрать все записи с таблицы ah_gallery но не более чем 10 с каждой категории

27.05.2016, 19:37. Показов 1413. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
привет всем!

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

*****

задача: выбрать все записи с таблицы ah_gallery но не более чем 10 с каждой категории
проблема: имеющийся запрос выбирает записи по очереди.. а нужно чтобы с каждой категории максимум 10 было

*****

запрос:
MySQL
1
set @n=1, @i=0, @p=0;
MySQL
1
select `ah_categories`.`id`, `ah_categories`.`title` from `ah_gallery` LEFT JOIN `gallery_category` ON `ah_gallery`.`id` = `gallery_category`.`gallery_id` LEFT JOIN `ah_categories` ON `gallery_category`.`category_id` = `ah_categories`.`id` where if(@p=`ah_categories`.`id`, @i:=@i+1,(@i:=0) or (@p:=`ah_categories`.`id`)) and @i<@n ORDER BY `ah_gallery`.`id` DESC;
*****

таблица ah_gallery:
MySQL
1
2
3
4
5
6
7
8
9
10
11
12
CREATE TABLE IF NOT EXISTS `ah_gallery` (
  `id` mediumint(9) NOT NULL AUTO_INCREMENT,
  `title` varchar(255) NOT NULL,
  `bullet` text NOT NULL,
  `description` text NOT NULL,
  `price` float NOT NULL DEFAULT '0',
  `price_muted` float DEFAULT NULL,
  `created` int(11) NOT NULL,
  `updated` int(11) NOT NULL,
  `status` tinyint(4) NOT NULL DEFAULT '1',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;
таблица ah_categories:
MySQL
1
2
3
4
5
6
7
CREATE TABLE IF NOT EXISTS `ah_categories` (
  `id` smallint(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL,
  `pseudo` varchar(50) NOT NULL,
  `status` tinyint(4) NOT NULL DEFAULT '1',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;
таблица gallery_category (соеденяющая):
MySQL
1
2
3
4
CREATE TABLE IF NOT EXISTS `gallery_category` (
  `gallery_id` mediumint(9) NOT NULL,
  `category_id` smallint(9) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
*****

п.с. связь между таблицами ah_gallery и ah_categories многие ко многим
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.05.2016, 19:37
Ответы с готовыми решениями:

Достать все товары, которые принадлежат более чем одной категории
Я это сделал, вывел так: название продукта и название категории, через запятую, можно ли вывести не так, а что бы выводило каждый раз...

Выбрать по 1 записи из таблицы 2 для каждой записи из таблицы 1
В таблице Document_Action по несколько записей для некоторых (не для всех) записей из таблицы Payment. Нужно выбрать по 1 из...

Как выбрать из таблицы все 50-ые записи?
Всего 100000 записей, как сделать такую выборку: 1 50 100 ... 95550 100000 ?

2
411 / 365 / 142
Регистрация: 09.04.2011
Сообщений: 1,051
27.05.2016, 22:07
Лучший ответ Сообщение было отмечено Rabeshko как решение

Решение

если бы прочитали тему до конца, то нашли бы решение, и понимание, что с т.з. производительности лучше выбрать категории и в цикле для каждой выбрать по 10 записей
1
1 / 1 / 1
Регистрация: 28.11.2013
Сообщений: 36
30.05.2016, 11:41  [ТС]
действительно не заметил.. сори за это

все решил этот "читерский" запрос:
MySQL
1
2
3
set @n=3, @i=0, @p=0;
 
select * from (select *, if (@p=x, @i:=@i+1,(@i:=0) or (@p:=x)) and (@i<@n) AS f from g t1 join p t2 on t1.x=t2.y) xx where f;
еще раз спасибо за ответ)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.05.2016, 11:41
Помогаю со студенческими работами здесь

Выбрать все записи с определенным словом из таблицы
работаю в делфи выбрать все записи с определенным словом из таблицы в поле не одно слово например &quot;кп5000.100.20 РУКАВ&quot; как...

Склеить таблицы при этом выбрать все записи из первой
SELECT * FROM Main INNER JOIN USD ON Main.ID_D = USD.ID_D INNER JOIN C_Inf ON C_Inf.ID_C = Main.ID_C INNER JOIN Value ON...

Выбрать в одном запросе все записи одной таблицы и счётчик второй
Доброго всем времени суток! Есть две таблицы, одна со списком пользователей, вторая со списком их прав. Идея состоит в том, что в...

Вывод категории в каждой отдельной записи
Здравствуйте, подскажите пожалуйста решение. Нужно чтобы в каждой отдельной записи выводилась своя заданная рубрика. Например в записи...

Как достать по одной записи каждой категории?
Есть бд в ней поле plaсeParsing это категория. есть другое поле datePublication это дата так вот мне нужно достать по последней дате,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru