Текущий архив: 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.017 c