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

Вниз

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

 
Tariel   (2004-06-14 09:48) [0]

У меня было два вложенных запроса, один был связан с внешней, но я думал что слишком накладно вызывать подзапрос к каждой записи и раелизовал другой запрос, где вложенный не зависит от внешнего, но только скорость не увеличилась. У меня есть подозрение что InterBase/FireBird вызывает подзапрос для каждой записи независимо от того связан он с внешним или нет.
Вот пример
1.
select * from MyTable outer
where
( select Max(MyField)
 from MyTable
 WHERE outer.ID = ID) = MyField
2.
select * from MyTable
where
 MyField in
   (select Max(MyField) from MyTable)


 
Tariel   (2004-06-14 09:56) [1]

Забыл,во стором есть еще group by, а выполняется он в раз пять медленнее


 
Anry   (2004-06-14 10:43) [2]

Посмотри план запроса. Если NATURAL чтение то IBase делает тебе полный перебор. Попробуй оптимизировать добавив нужные индексы, только не перебарщивай с их количеством (только необходимые).


 
Johnmen ©   (2004-06-14 17:24) [3]

Если подзапрос полностью автономен, то он выполнится один раз. По кр.мере в случае последних версий сервера.
Второй запрос выполняется долго, т.к. группировка очень ресурсоемкая операция, особенно по времени...


 
Romkin ©   (2004-06-14 17:28) [4]

А если подзапрос зависит от внешнего, то он выполнится для каждой строки



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

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

Наверх




Память: 0.47 MB
Время: 0.037 c
3-1086973523
Vetek
2004-06-11 21:05
2004.07.11
SQL-запрос - выборка популярных значений


1-1088054215
nick
2004-06-24 09:16
2004.07.11
Как освободить память


8-1082823159
Namo
2004-04-24 20:12
2004.07.11
Delphi 8 + Flash


14-1088146812
Kolyan
2004-06-25 11:00
2004.07.11
Pungvini Rulyat!!!!


14-1087717818
Anatoly Podgoretsky
2004-06-20 11:50
2004.07.11
С днем рождения 19.06.2004