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

Вниз

200 как отключить авто оптимизацию запроса?   Найти похожие ветки 

 
Vadim S   (2003-10-07 12:40) [0]

Есть запрос

SELECT SKLAD2.KOD, KOLVO.ID_RAZMER, KOLVO.ID_ROST, SKLADS.ID_SKLAD, COUNT(*) AS Expr1
FROM KOLVO,SKLADS,SKLAD2
WHERE KOLVO.ID_TOVAR = SKLAD2.ID_TOVAR AND KOLVO.ID_SKLAD = SKLADS.ID_SKLAD AND (SKLAD2.KOD LIKE "XCOD")
GROUP BY SKLAD2.KOD, KOLVO.ID_RAZMER, KOLVO.ID_ROST, SKLADS.ID_SKLAD
ORDER BY SKLAD2.KOD, KOLVO.ID_RAZMER, KOLVO.ID_ROST, SKLADS.ID_SKLAD


SQL2000 преобразует его к

SELECT SKLAD2.KOD, KOLVO.ID_RAZMER, KOLVO.ID_ROST, SKLADS.ID_SKLAD, COUNT(*) AS Expr1
FROM KOLVO
INNER JOIN SKLADS ON KOLVO.ID_SKLAD = SKLADS.ID_SKLAD
INNER JOIN SKLAD2 ON KOLVO.ID_TOVAR = SKLAD2.ID_TOVAR
WHERE (SKLAD2.KOD LIKE "XKOD")
GROUP BY SKLAD2.KOD, KOLVO.ID_RAZMER, KOLVO.ID_ROST, SKLADS.ID_SKLAD
ORDER BY SKLAD2.KOD, KOLVO.ID_RAZMER, KOLVO.ID_ROST, SKLADS.ID_SKLAD


Как отключить автооптимизацию, чтобы запросы выполнялись "как есть"?

А что FROM выполняется медленней INNER JOIN ???


 
Sedunov Vitaly   (2003-10-07 13:16) [1]

Можно запускать через exec(<строка запроса>) и тогда, на мой взгляд, оптимизации не будет.


 
Vadim S   (2003-10-07 13:21) [2]

Как только на "!"
нажимаю или на "V" (check)
Сразу идет оптимизация.

PS Все это яделаю в EM.


 
stone ©   (2003-10-07 13:30) [3]

А ты делай в Query Analyzer

Хотя он же не зря оптимизирует, JOIN правильнее будет в отношении рационального использования индексов


 
Fiend ©   (2003-10-07 13:39) [4]

оптимизацию делают не QA и EM, ее выполняет сервер. если будете выполнять динамический запрос, тоже будет оптимизация.

Совет: не надо отказываться от оптимизации сервером, ибо он достаточно "умный" чтобы сделать ее правильно! Не надейтесь его обыграть на этом поле.


 
Vadim S   (2003-10-07 13:49) [5]

Правильный ответ был

SET FORCEPLAN OFF (уже подсказали)

Всем спасибо.


 
ZrenBy ©   (2003-10-07 13:49) [6]

>>INNER JOIN SKLADS ON KOLVO.ID_SKLAD = SKLADS.ID_SKLAD
>>INNER JOIN SKLAD2 ON KOLVO.ID_TOVAR = SKLAD2.ID_TOVAR
>>WHERE (SKLAD2.KOD LIKE "XKOD")

Здесь нет абсолютно никакой оптимизации.
Просто все приведено к грамотному стилю.
Горяздо прозрачней, когда в секции join - критерии связи,
а в секции where - критерии отбора.



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

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

Наверх




Память: 0.48 MB
Время: 0.04 c
14-89475
race1
2003-10-09 17:07
2003.10.27
modelmaker


14-89546
ИМХО
2003-10-07 22:47
2003.10.27
Приобрести компакт-диски с музыкой


7-89626
Andrew
2003-08-14 19:45
2003.10.27
Print screen


6-89419
Support1
2003-09-01 21:39
2003.10.27
Определение скорости Инета


14-89571
Yakudza
2003-10-07 14:18
2003.10.27
CoInitialize has not been called