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

Помогите сообразить, пожалуйста (Запрос на Sql)!!

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



Зарегистрирован: 22.12.2001
Сообщения: 25
Откуда: Сергиев Посад

СообщениеДобавлено: Ср Мар 13 2002 14:31    Заголовок сообщения: Помогите сообразить, пожалуйста (Запрос на Sql)!! Ответить с цитатой

Так использоваться оператор IN:

Select tab1.*
from tab1
where (tab1.field1, tab1.field2) not IN (select tab2.field1, tab2.field2 from tab2)

к сожалению, не может (только один столбец должен быть слева и справа от него). Может, кто-нибудь посоветует, как попроще реализовать подобный запрос?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
Евгений Григорьев
Гость





СообщениеДобавлено: Ср Мар 13 2002 16:16    Заголовок сообщения: Re: Помогите сообразить, пожалуйста (Запрос на Sql)!! Ответить с цитатой

Если не ошибаюсь, в результате должны быть строки с парой полей f1 и f2 не встречающихся (вместе или по отдельности) в Tab2.

Можно без IN

SELECT Tab1.* FROM Tab1 LEFT JOIN Tab2 ON (Tab1.f1 = Tab2.f1) AND (Tab1.f2 = Tab2.f2)
WHERE (((Tab2.f1) Is Null) AND /*...AND - это вместе, OR - по отдельности... */ ((Tab2.f2) Is Null));
Вернуться к началу
Andrey Barashkin
Гость





СообщениеДобавлено: Ср Мар 13 2002 21:27    Заголовок сообщения: Re: Помогите сообразить, пожалуйста (Запрос на Sql)!! Ответить с цитатой

Select tab1.*
from tab1
where (tab1.field1, tab1.field2) not IN (select tab2.field1, tab2.field2 from tab2)

Преевратите в следующий вариант

Select tab1.*
from tab1
where NOT EXISTS (select 1 from tab2 Where tab1.field1 = tab2.field1 and tab1.field2 = tab2.field2 )
Вернуться к началу
GAI
Гость





СообщениеДобавлено: Пт Мар 15 2002 05:57    Заголовок сообщения: Re: Помогите сообразить, пожалуйста (Запрос на Sql)!! Ответить с цитатой

Для нецелострочного несовпадения:
SELECT *
FROM t1
WHERE (((f1) Not In (Select f1 from t2)) AND(или OR) ((f2) Not In (Select f2 from t2)));

Для полнострочного несовпадения:
SELECT tab1.*
FROM tab1 LEFT JOIN tab2 ON (tab1.field2 = tab2.field2) AND (tab1.field1 = tab2.field1)
WHERE (((tab2.field1) Is Null)) AND(или OR)(((tab2.field2) Is Null));

Удачись на АнтиЛамера!
Удачи!
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: 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
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...