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

Вниз

План выполнения подзапросов   Найти похожие ветки 

 
PrettyFly   (2002-10-28 13:04) [0]

Я всегда думал, что IB выполняет запросы поумному, но оказалось, что это совсем не так...


SELECT * FROM B
WHERE
B.G IN (SELECT C.G FROM C WHERE C.ID IN(1,2,3,4,5,6,7,8,9,10))
AND (B.P = 6)


Надо сначала выполнить внутренний SELECT один раз, а потом уже внешний. А выполняется внешний, и для каждой записи внутренний.
В результате, вместо M+N, время выполнения получается М*N. Как это можно исправить?


 
passm ©   (2002-10-28 13:59) [1]

PrettyFly (28.10.02 13:04)> Не знаю... Но могу предложить альтернативный запрос:
SELECT DISTINCT B.*
FROM B
INNER JOIN C ON (C.G = B.G)
WHERE C.ID IN (1,2,3,4,5,6,7,8,9,10)
AND B.P = 6
Но, это странно. Т. к. во внутреннем запросе не использкуется B :\ .


 
Desdechado ©   (2002-10-28 17:09) [2]

Ничего странного. Это ж механизм подзапроса. А в нем предусмотрено именно так: для каждой выбираемой строки основного запроса выполнить подзапрос (вне зависимости от его вида и кажущейся простоты).
А лучше выполни обычное объединение, оно эффективнее и доступнее для понимания :)



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

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

Наверх




Память: 0.47 MB
Время: 0.016 c
14-59339
Relict
2002-11-01 09:08
2002.11.18
крестики нолики


7-59453
SKing
2002-09-17 17:00
2002.11.18
ESC P (Портрет-Ландшафт)????


1-59140
Zn
2002-11-08 16:06
2002.11.18
Индикация выполнения процесса в StatusBar.


3-59031
Matvey
2002-10-28 21:18
2002.11.18
DBLookupComboBox программное позиционирование?


14-59431
Карлсон
2002-10-30 20:20
2002.11.18
электроны....