Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Что -то я с заданием условия в WHERE сообразить не могу...

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
Рубрикатор
Гость





СообщениеДобавлено: Чт Окт 02 2003 10:33    Заголовок сообщения: Что -то я с заданием условия в WHERE сообразить не могу... Ответить с цитатой

Есть значит таблица заголовков заказа

THeader( ID#, OrderNO, Date)

И еще таблица, где перечислены позиции заказа

TItem( ID#, Article#, Pieces)

Мне понятно, как найти номера всех заказов, по которым отгружается некий артикул (назовем его А1)

SELECT THEader.OrderNO
FROM THeader INNER JOIN TItem ON THeader.ID# = TItem.ID#
WHERE TItem.Article="A1"

Также мне понятно, как найти номера всех заказов, по которым отгружается некий артикул (А1) или другой артикул (A2)

SELECT THEader.OrderNO
FROM THeader INNER JOIN TItem ON THeader.ID# = TItem.ID#
WHERE TItem.Article="A1" OR TItem.Article="A2"

Но я никак не могу догнать, как мне в одно SQL выражение написать запрос, возвращающий номера заказов, по которым отгружается И артикул (А1) И артикул (A2). Вариант

....WHERE TItem.Article="A1" AND TItem.Article="A2"

естественно не пройдет
Вернуться к началу
Andy-C
Гость





СообщениеДобавлено: Пн Окт 06 2003 07:37    Заголовок сообщения: Re: Что -то я с заданием условия в WHERE сообразить не могу... Ответить с цитатой

первое что приходит в голову:
select * from header h where exists
(select id from item where ih=h.id and art=1)
and
exists
(select id from item where ih=h.id and art=2)

можно навороченей ( и универсальней)

select h.name from header h,item i where i.ih=h.id and (i.art=1 or i.art=2)
group by h.name
having count(distinct i.art)=2
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...