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

Вниз

Составить оптимальный запрос   Найти похожие ветки 

 
onix   (2003-10-22 13:15) [0]

Добрый день уважаемые. Помогите составить запрос оптимальней, а то чего-то я совсем заморочился. (БД Firebird)
Усть две таблицы. Необходимо выбрать ФИО из 1-й табл. у которых нет записей во 2-й. Я написал так:

select STUDENT_ID, STUDENT_SURNAME
from DEAN_STUDENT
where not Exists (select *
from DEAN_MOVEMENT, DEAN_STUDENT
where M_STUDENT=STUDENT_ID)
но всегда выдает пустой список(???), а вот такой запрос работает очень долго:
seleсе STUDENT_SURNAME
from DEAN_STUDENT");

where STUDENT_ID not in (select M_STUDENT
from DEAN_MOVEMENT,DEAN_STUDENT
where M_STUDENT=STUDENT_ID)


 
Семен Сорокин ©   (2003-10-22 14:22) [1]

индексы есть?
попробуй использовать join.


 
Nikolay M. ©   (2003-10-22 14:33) [2]

Не скажу точно, как оно в IB/FB, но может в первом запросе возникает неоднозначность в
select * from DEAN_MOVEMENT, DEAN_STUDENT where M_STUDENT= STUDENT_ID
(кстати, а почему *?)
поскольку DEAN_STUDENT используется в основном SELECT?

И зачем во втором запросе делать в подзапросе связку по двум таблицам? Если нужно отбросить значения только из одной таблицы?



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

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

Наверх




Память: 0.47 MB
Время: 0.015 c
1-8524
Igit
2003-10-22 20:33
2003.11.03
PBITMAP по HBITMAP


3-8262
IBNovice
2003-10-14 15:57
2003.11.03
LookUp in DBGrid


1-8528
TRyaSS
2003-10-23 14:59
2003.11.03
Сообщение об открытии какой-либо программы


1-8348
MaXie
2003-10-23 12:01
2003.11.03
Как дождаться завершение приложения?


1-8518
Raduga
2003-10-23 16:21
2003.11.03
какой компанент использовать?