Can you help with this JOIN?

From: Wei Weng <wweng(at)kencast(dot)com>
To: pgsql-sql(at)postgresql(dot)org
Subject: Can you help with this JOIN?
Date: 2002-05-29 16:06:14
Message-ID: 1022688374.26733.5.camel@Monet
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

I have a massive join that takes something like 10 seconds to execute in
Postgresql 7.2. Can any of gurus here help me improve it?

It is as follows:

SELECT DISTINCT cs.ContentID AS cscid, ct.Name AS ctname, pb.Name AS
pbname, cs.Author AS author, cs.CreationDate AS fromtime, cs.ExpireDate
AS totime, ct.Name AS media
FROM
ContentSummaries AS cs JOIN ContentTypes AS ct ON (ct.ContentTypeID =
cs.ContentTypeID)
JOIN ContentAttributes AS cab ON (cab.ContentID = cs.ContentID)
JOIN Attributes AS ab ON (ab.AttributeID = cab.AttributeID)
JOIN Categories AS cat ON (cat.CategoryID = cs.CategoryID)
LEFT OUTER JOIN Publishers AS pb ON (pb.PublisherID = cs.PublisherID)
WHERE cs.CreationDate IS NOT NULL

I already created indexes on all possible fields in those tables.

the query plan:

Limit (cost=3170.75..3173.00 rows=15 width=172)
-> Unique (cost=3170.75..3203.77 rows=220 width=172)
-> Sort (cost=3170.75..3170.75 rows=2201 width=172)
-> Nested Loop (cost=611.64..3048.54 rows=2201
width=172)
-> Hash Join (cost=611.64..3021.02 rows=2201
width=148)
-> Hash Join (cost=610.61..2931.93 rows=2201
width=136)
-> Hash Join (cost=609.44..2842.53
rows=2201 width=124)
-> Seq Scan on contentattributes
cab (cost=0.00..867.05 rows=33005 width=24)
-> Hash (cost=600.27..600.27
rows=3667 width=100)
-> Hash Join
(cost=1.02..600.27 rows=3667 width=100)
-> Seq Scan on
contentsummaries cs (cost=0.00..452.52 rows=3667 width=76)
-> Hash
(cost=1.02..1.02 rows=2 width=24)
-> Seq Scan on
contenttypes ct (cost=0.00..1.02 rows=2 width=24)
-> Hash (cost=1.14..1.14 rows=14
width=12)
-> Seq Scan on attributes ab
(cost=0.00..1.14 rows=14 width=12)
-> Hash (cost=1.02..1.02 rows=2 width=12)
-> Seq Scan on categories cat
(cost=0.00..1.02 rows=2 width=12)
-> Seq Scan on publishers pb (cost=0.00..0.00
rows=1 width=24)

Thanks in advance. I had been really scratching my head for this one.

--
Wei Weng
Network Software Engineer
KenCast Inc.

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message achill 2002-05-29 16:19:17 Re: Trees in SQL
Previous Message Christopher Kings-Lynne 2002-05-28 21:12:28 Re: query system tables to find columns unique constraint is constraining?