Re: triple self-join crawling - Mailing list pgsql-sql

From T E Schmitz
Subject Re: triple self-join crawling
Date
Msg-id 45FEB5C7.5010406@numerixtechnology.de
Whole thread Raw
In response to Re: triple self-join crawling  (Andrew Sullivan <ajs@crankycanuck.ca>)
List pgsql-sql
Andrew Sullivan wrote:
> Define "crawling".  Also, please post EXPLAIN and, if feasible,

Total runtime: 191430.537 ms


> EXPLAIN ANALYSE output for your case.
> 
> On Sun, Mar 18, 2007 at 07:51:28PM +0000, T E Schmitz wrote:
> 
>>The following self join of a table containing 5800 records is crawling:
>>
>>
>>SELECT
>>    history.stock, history.day, history.high, history.low,
>>    MAX(past_week.high) AS week_high,
>>    MAX(past_month.high) AS month_high
>>FROM history
>>INNER JOIN history AS past_month ON (past_month.stock = history.stock 
>>AND past_month.day < history.day AND past_month.day >= (history.day - 30))
>>INNER JOIN history AS past_week  ON (past_week.stock   = 
>>past_month.stock AND past_week.day < history.day AND past_week.day >= 
>>(history.day - 7))
>>GROUP BY  history.stock, history.day, history.high, history.low
>>ORDER BY history.stock, history.day DESC

QUERY PLAN
GroupAggregate  (cost=1372725715.71..1414901439.85 rows=5801 width=56) 
(actual time=185248.481..191393.056 rows=5800 loops=1)  ->  Sort  (cost=1372725715.71..1378750806.73 rows=2410036407 
width=56) (actual time=185247.212..187763.008 rows=584203 loops=1)        Sort Key: history.stock, history."day",
history.high,history.low        ->  Nested Loop  (cost=0.00..132245248.41 rows=2410036407 
 
width=56) (actual time=0.124..148136.464 rows=584203 loops=1)              Join Filter: (("inner".stock)::text =
("outer".stock)::text)             ->  Nested Loop  (cost=0.00..555931.84 rows=3739067 
 
width=53) (actual time=0.087..137531.941 rows=28147 loops=1)                    Join Filter: (("outer"."day" >=
("inner"."day"- 
 
7)) AND (("outer".stock)::text = ("inner".stock)::text))                    ->  Index Scan using history_pkey on
history
 
past_week  (cost=0.00..266.62 rows=5801 width=23) (actual 
time=0.034..43.147 rows=5801 loops=1)                    ->  Index Scan using idx_history_day on history 
(cost=0.00..57.11 rows=1934 width=34) (actual time=0.021..12.709 
rows=2900 loops=5801)                          Index Cond: ("outer"."day" < history."day")              ->  Index Scan
usingidx_history_day on history 
 
past_month  (cost=0.00..22.32 rows=645 width=23) (actual 
time=0.019..0.170 rows=21 loops=28147)                    Index Cond: ((past_month."day" < "outer"."day") AND 
(past_month."day" >= ("outer"."day" - 30)))
Total runtime: 191430.537 ms

-- 


Regards,

Tarlika Elisabeth Schmitz


pgsql-sql by date:

Previous
From: T E Schmitz
Date:
Subject: Re: triple self-join crawling
Next
From: Jure Kodzoman
Date:
Subject: Re: Encode