Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.03.27;
Скачать: CL | DM;

Вниз

Как правильно написать select ... in по двум полям?   Найти похожие ветки 

 
SergP ©   (2005-02-24 19:05) [0]

Пишу примерно так:
select * from table1
  where field1||"/"||field2 not in
   (select field1||"/"||field2 from table2)

Оно работает. Только есть сомнения в том насколько правильно использовать в таком случае конкатентацию.

Есть ли еще какие-нить способы делать select ... in по нескольким полям?


 
SergP ©   (2005-02-24 19:08) [1]

имеется ввиду то что символа "/" не может быть в вышеуказаных полях.


 
SergP ©   (2005-02-24 19:11) [2]

СУБД Oracle


 
JohnnyJ ©   (2005-02-24 20:25) [3]

с учетом [1]:

select *
from table1 as a
where not exists (select 1
                 from table2 as b
                 where b.field1 = a.field1
                   and b.field2 = a.field2);

и построить индекс на table2 по field1 и field2.


 
SergP ©   (2005-02-24 23:44) [4]


> и построить индекс на table2 по field1 и field2.


это обязательное условие или просто желательное для ускорения выполнения запроса?



Страницы: 1 вся ветка

Текущий архив: 2005.03.27;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.035 c
1-1110372935
Green_Templar
2005-03-09 15:55
2005.03.27
Самооптимизация


3-1109089238
Bogdan
2005-02-22 19:20
2005.03.27
Редактирование записи.


3-1109601566
Alexander1
2005-02-28 17:39
2005.03.27
Создание БД (программно)


6-1106561507
Stalker_
2005-01-24 13:11
2005.03.27
Отправка почты через idSMTP


1-1110466961
markers
2005-03-10 18:02
2005.03.27
Stream/BlowFish-TurboPower