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

Вниз

Странно работает запрос.   Найти похожие ветки 

 
Семен Кевларвестов   (2008-11-26 18:36) [0]

Доброго вечера!

В TQuery есть запрос вида:

select T1.Table1ID,
        T2.Table2ID,
        T3.Table3ID
from table1 T1 (nolock)
left join table2 T2 (nolock) on T2.Table2ID = T1.Table2ID
left join table3 T3 (nolock) on T3.Table3ID = T2.Table3ID
where T2.Table2ID = @SomeParam1 and
        T3.Table3ID = @SomeParam2

и в таком виде это работает очень медленно,

но если сделать так:


select T1.Table1ID,
        T2.Table2ID,
        T3.Table3ID
from table1 T1 (nolock)
left join table2 T2 (nolock) on T2.Table2ID = T1.Table2ID
left join table3 T3 (nolock) on T3.Table3ID = T2.Table3ID
where T1.Table2ID = @SomeParam1
        T3.Table3ID = @SomeParam2


то все начинает работать очень быстро.

В QueryAnalyzer все работает одинаково, по крайней мере я разницы не заметил. Почему так?


 
clickmaker ©   (2008-11-26 18:42) [1]

потому что во втором случае сначала отбираются записи в Т1, а потом уже накладывается джоин
в QueryAnalyzer, возможно, хороший парсер запросов, он приводит первый вариант к более оптимальному



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

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

Наверх




Память: 0.46 MB
Время: 0.014 c
2-1227705341
MS
2008-11-26 16:15
2009.01.11
Указатель на тип string


15-1226564342
Нов_и_чок
2008-11-13 11:19
2009.01.11
Справочник Win32 для XP


15-1226952249
NoDt
2008-11-17 23:04
2009.01.11
Поясните пожалуста Алгоритм Дейкстры


15-1226316266
Долетел
2008-11-10 14:24
2009.01.11
КПК / коммуникаторы


1-1205380631
snake-as
2008-03-13 06:57
2009.01.11
Посылка письма