Re: Query/database optimization

Поиск
Список
Период
Сортировка
От Eugeny N Dzhurinsky
Тема Re: Query/database optimization
Дата
Msg-id 20060802105622.GA2627@office.redwerk.com
обсуждение исходный текст
Ответ на Re: Query/database optimization  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-performance
On Tue, Aug 01, 2006 at 11:15:11PM -0400, Tom Lane wrote:
> Eugeny N Dzhurinsky <bofh@redwerk.com> writes:
> > [slow query]
> The bulk of your time seems to be going into this indexscan:
> >                                  ->  Index Scan using task_scheduler_icustomer_id on task_scheduler ts
(cost=2.03..11.51rows=1 width=51) (actual time=2.785..2.785 rows=0 loops=4161) 
> >                                        Index Cond: ("outer".customer_id = ts.customer_id)
> >                                        Filter: ((get_available_pages(task_id, customer_id) > 0) AND
((get_check_period(task_id,next_check) IS NULL) OR ((date_part('epoch'::text, get_check_period(task_id, next_check)) -
date_part('epoch'::text,(timenow())::timestamp without time zone)) < 3600::double precision)) AND (status <> 1) AND
((((start_time)::timewith time zone < ('now'::text)::time(6) with time zone) AND ((stop_time)::time with time zone >
('now'::text)::time(6)with time zone)) OR ((start_time IS NULL) AND (stop_time IS NULL))) AND (NOT (hashed subplan))) 
> >                                        SubPlan
> >                                          ->  Unique  (cost=2.02..2.03 rows=1 width=4) (actual time=0.617..0.631
rows=3loops=1) 
> > ...
>
> I kinda doubt that the index search itself is that slow --- doubtless
> the problem comes from having to evaluate that filter condition on a lot
> of rows.  How fast are those functions you're calling?

Well, not really fast, especially get_available_pages

there is special table with history of changes, and there is a view for latest
changes per task, and this function selects all records from a view for given
ID, then calculates sum of pages of tasks and then calculates number of
available pages as number of allowed pages deduct number of processed pages.

probably there is bottleneck in this view selection?

--
Eugene N Dzhurinsky

В списке pgsql-performance по дате отправления:

Предыдущее
От: Tom Lane
Дата:
Сообщение: Re: Query/database optimization
Следующее
От: H Hale
Дата:
Сообщение: Re: sub select performance due to seq scans