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

Вниз

Глюк с запросом   Найти похожие ветки 

 
raptor3   (2006-04-06 06:15) [0]

select sum(quantity),sum(items.discount_price) from items
inner join orders on items.id_order=orders.id_order
inner join client c1 on items.id_client_to=client.id_client
inner join client c2 on orders.id_client_from=client.id_client
inner join service on service.id_service=items.id_service
inner join format on format.id_format=items.id_format
where f_month(orders.date_order)=:month_ and f_year(orders.date_order)=:year_
and not(items.status=1 and items.status is not null)
and id_client_from not in (13,27,28,30,31,4122,3594,6732)
and id_client_from=:id_client
and c1.id_edition=:id_edition

запрос работает правильно и выдает результат через пару минут

однако если я подставляю "and id_client_to=:i" в условие проверки, где i в цикле от 1 до 6, от выборка затягивается на 5 часов


 
Ильш ©   (2006-04-06 06:37) [1]

а что говорит план запроса ?


 
ЮЮ ©   (2006-04-06 09:16) [2]

1)
f_month(orders.date_order)=:month_ and f_year(orders.date_order)=:year_

Заменить на orders.date_order between :DateFrom and :DateTo ( + индекс по orders.date_order)

2) убрать
and id_client_from not in (13,27,28,30,31,4122,3594,6732) - ибо медленный и большей частью противоречит
and id_client_from=:id_client
Ограничения лучше перенести на этап формирования :id_client


 
Sandman25 ©   (2006-04-06 09:41) [3]

Сделать item.status not null, вместо null присвоить, скажем, 0.
Тогда условие and not(items.status=1 and items.status is not null)
упростится до (item.status <> 1)


 
ЮЮ ©   (2006-04-06 09:57) [4]

not(items.status=1 and items.status is not null) == not(items.status=1) ==  (item.status <> 1)
и без преобразований ибо NULL <> 1.

and items.status is not null вообще лишнее


 
Desdechado ©   (2006-04-06 12:23) [5]

> Глюк с запросом [D5, IB6.x]
> запрос работает правильно
я так и не понял...


 
raptor3@mail.ru   (2006-04-11 13:40) [6]

индекс по полю id_client_to был косяченный - как только его удалил - прога заработала как надо



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

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

Наверх




Память: 0.47 MB
Время: 0.049 c
3-1140673919
vlgrig1961
2006-02-23 08:51
2006.04.23
Портятся индексы как с этим бороться


15-1144165279
Бугага
2006-04-04 19:41
2006.04.23
Автоматизация идет полным ходом :)


15-1144042656
Ega23
2006-04-03 09:37
2006.04.23
С Днём рождения! 3 апреля


1-1142710002
Volf_555
2006-03-18 22:26
2006.04.23
Как скопировать текст в буффер обмена с минималь. размером файла?


2-1144662432
Volodya_
2006-04-10 13:47
2006.04.23
com port