Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Одно множество входит в другое 
V
    Опции темы
WolfON
Дата 28.11.2007, 23:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 604
Регистрация: 19.7.2004

Репутация: нет
Всего: 8



Есть таблица вида:
group_id | service_id
1             | 2
1             | 3
1             | 4
1             | 5
1             | 6
2             | 2
2             | 3
2             | 4
2             | 3


Каким образом можно выбрать все group_id, внутри групп которых обязательно есть, допустим 2,3 и 4?

Это сообщение отредактировал(а) WolfON - 28.11.2007, 23:13
PM MAIL ICQ   Вверх
skyboy
Дата 29.11.2007, 01:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


неОпытный
****


Профиль
Группа: Модератор
Сообщений: 9820
Регистрация: 18.5.2006
Где: Днепропетровск

Репутация: 41
Всего: 260



Цитата(WolfON @  28.11.2007,  22:12 Найти цитируемый пост)
выбрать все group_id, внутри групп которых обязательно есть, допустим 2,3 и 4?

если "2,3,4" - это значения group_id, то запрос выглядит так:
Код

SELECT `group_id`, `service_id` FROM `table` WHERE `group_id` in (2,3,4)

если "2,3,4" - это значения service_id:
Код

SELECT `group_id`,`service_id` FROM `table` WHERE `service_id` IN (2,3,4)

если необходимо, чтоб grouр_id выводились без дублирования, то либо с группировкой(ну, чтоб в твоем посте слово "группа" н просто так стояло):
Код

SELECT `group_id`
FROM `table` 
WHERE `service_id` IN (2,3,4)
GROUP BY `group_id`

или, что лучше, потому что быстрее, потому что проще:
Код

SELECT DISTINCT `group_id`
FROM `table` 
WHERE `service_id` IN (2,3,4)

PM MAIL   Вверх
WolfON
Дата 29.11.2007, 01:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 604
Регистрация: 19.7.2004

Репутация: нет
Всего: 8



2,3,4 - это service_id

проблема в том, что IN eq ИЛИ, а мне надо И

те: выбрать все group_id, где внутри каждой из выбранных групп находятся все заданные значения service_id

Это сообщение отредактировал(а) WolfON - 29.11.2007, 01:10
PM MAIL ICQ   Вверх
Akina
Дата 29.11.2007, 01:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 454



Код

SELECT `group_id`
FROM `table` 
WHERE `service_id` IN (2,3,4)
GROUP BY `group_id`
HAVING Count(`group_id`)=3



--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
WolfON
Дата 29.11.2007, 14:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 604
Регистрация: 19.7.2004

Репутация: нет
Всего: 8



то что надо - спасибо smile

зыж: запостил в начале в конфу по бд в разделе пхп, по тому что на вопросы которые я задавал в этой как правило не отвечали - меньше людей смотрит видимо
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




[ Время генерации скрипта: 0.1152 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.