@www3

Как выдать верный результат SQL?

Добрый день! Имеется таблица товар(id, опция) и выглядит она примерно так
id | опция
1 | 1
1 | 2
2 | 1
2 | 3
3 | 2
...
Как сформировать запрос так, чтобы вывести например товар с опциями 1, 2?
  • Вопрос задан
  • 263 просмотра
Решения вопроса 1
Winsik
@Winsik
сис.админ, недопрограммист :)
SELECT id FROM  T  where o =1 and id in (select id from t where o=2)

вариант два:
select id from (
  select id, max(o1) as o1, max(o2) as o2 from (
      select id,1 as o1, 0 as o2 from T where o = 1
    union
      select id,0 as o1, 1 as o2 from T where o = 2
  ) as T1 group by id
) as T2
where o1=1 and o2=1
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы