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

Вниз

SQL запрос c not in   Найти похожие ветки 

 
MZ   (2007-08-27 11:11) [0]

уважаемые мастера! Необходимо составиь запрос который отбирает записи из таблицы Table1 у которых совокупность 2 полей (поля индексированы) не равна
совокупности этих полей в Table2. Сделал так

SELECT*
FROM TABLE1
WHERE FIELD1||FIELD2 NOT IN
(SELECT FIELD1||FIELD2
FROM TABLE2)

Как-то это коряво.... И поиск соответственно не индексирован...


 
turbouser ©   (2007-08-27 11:21) [1]

SELECT*
FROM TABLE1 t1
WHERE NOT EXISTS
(SELECT * FROM TABLE2 t2 WHERE t2.FIELD1=t1.FIELD1 and t2.FIELD2=t1.FIELD2)

или
(SELECT * FROM TABLE2 t2 WHERE t2.FIELD1||t2.FIELD2 and t1.FIELD1||t1.FIELD2)
- по обстоятельствам


 
turbouser ©   (2007-08-27 11:24) [2]

(SELECT * FROM TABLE2 t2 WHERE t2.FIELD1||t2.FIELD2 = t1.FIELD1||t1.FIELD2)


 
Вася Правильный   (2007-08-27 11:25) [3]


>  WHERE t2.FIELD1||t2.FIELD2 and t1.FIELD1||t1.FIELD2

это чё за конструкция?


 
MZ   (2007-08-27 11:32) [4]


> turbouser ©   (27.08.07 11:21) [1]
>
> SELECT*
> FROM TABLE1 t1
> WHERE NOT EXISTS
> (SELECT * FROM TABLE2 t2 WHERE t2.FIELD1=t1.FIELD1 and t2.
> FIELD2=t1.FIELD2)


Забыл про Exist :-(  спасибо, работает


 
Johnmen ©   (2007-08-27 11:43) [5]

Классическое решение:
SELECT T1.* FROM TABLE1 T1
LEFT JOIN TABLE1 T2 WHERE (T1.FIELD1=T2.FIELD1) AND (T1.FIELD2=T2.FIELD2)
WHERE T2.FIELD1 IS NULL



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

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

Наверх




Память: 0.47 MB
Время: 0.022 c
6-1170770912
Aks13
2007-02-06 17:08
2007.12.30
Twebbrouser координаты ссылки на странице.


3-1187355915
alsov
2007-08-17 17:05
2007.12.30
Разница вызова запроса


2-1196860535
Res
2007-12-05 16:15
2007.12.30
Потоки


2-1197033931
Максим
2007-12-07 16:25
2007.12.30
Проверка


15-1196343324
Slider007
2007-11-29 16:35
2007.12.30
С днем рождения ! 29 ноября 2007 четверг