Главная страница
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.012 c
6-59314
Fly``
2002-09-23 18:24
2002.11.18
Data Link Properties


14-59407
VladP
2002-10-28 10:48
2002.11.18
Вложенные свойства


4-59504
relict
2002-10-09 09:02
2002.11.18
отловить выключение компа


3-59025
DeLz
2002-10-29 18:22
2002.11.18
Может кто знает как в SQL передать параметер для IN (:ParamName)


1-59098
SiaCD
2002-11-08 02:11
2002.11.18
как завершить программу в Form1.FormCreate.....form1.close