Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Основная";
Текущий архив: 2003.11.03;
Скачать: [xml.tar.bz2];

Вниз

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

 
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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.44 MB
Время: 0.009 c
14-8654
Gorlum
2003-10-14 11:30
2003.11.03
Про создание карт


1-8358
Russko
2003-10-23 10:04
2003.11.03
ExcelApplication


1-8501
MaG
2003-10-23 20:02
2003.11.03
Шрифт


14-8606
Пубертанец
2003-10-15 11:26
2003.11.03
GetTempPath - выдает ошибку


1-8435
SniZ
2003-10-21 22:04
2003.11.03
Про внедрение в программу





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский