From: | John Sherwood <john(at)gleam(dot)io> |
---|---|
To: | pgsql-sql(at)postgresql(dot)org |
Subject: | PGSQL-Performance mailing list |
Date: | 2015-07-02 10:52:13 |
Message-ID: | CADDayd0e1suAhwH0__Z3M4VkgBmHkKbb+_rPG75mJJHMb0ZypQ@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Hi,
I'm having some trouble getting this query down for large users.
Basically, we deal with competition entries. For this customer (a.k.a.
site) we've got ~1,000,000 entries from ~100,000 contestants.
SELECT contestants.*, sum(entries.worth) as db_entries, count(entries.id)
as db_actions FROM "contestants" INNER JOIN "entries" ON
"entries"."contestant_id" = "contestants"."id" WHERE
"entries"."campaign_id" IN (SELECT id FROM "campaigns" WHERE
"campaigns"."site_id" = $1) AND (entries.status != 'Invalid') GROUP BY
contestants.id ORDER BY db_actions desc LIMIT 20 OFFSET 0
Here's the explain:
QUERY PLAN
----------------------------------------------------------------------------------------------------------------------------------------
Limit (cost=3783168.28..3783168.33 rows=20 width=103)
-> Sort (cost=3783168.28..3792902.85 rows=3893825 width=103)
Sort Key: (count(entries.id))
-> GroupAggregate (cost=3004896.86..3679555.00 rows=3893825
width=103)
-> Merge Join (cost=3004896.86..3611413.06 rows=3893825
width=103)
Merge Cond: (contestants.id = entries.contestant_id)
-> Index Scan using contestants_pkey on contestants
(cost=0.43..534782.85 rows=7490021 width=95)
-> Sort (cost=3004710.57..3014464.64 rows=3901628
width=12)
Sort Key: entries.contestant_id
-> Nested Loop (cost=19.88..2577567.27
rows=3901628 width=12)
-> Bitmap Heap Scan on campaigns
(cost=19.32..1332.62 rows=374 width=4)
Recheck Cond: (site_id = 152)
-> Bitmap Index Scan on
index_campaigns_on_site_id (cost=0.00..19.22 rows=374 width=0)
Index Cond: (site_id = 152)
-> Index Scan using
index_entries_on_campaign_id on entries (cost=0.57..6784.01 rows=10432
width=16)
Index Cond: (campaign_id =
campaigns.id)
Filter: ((status)::text <>
'Invalid'::text)
Any thoughts on tweaks I could apply to speed this up?
Thanks,
John
From | Date | Subject | |
---|---|---|---|
Next Message | Greg Sabino Mullane | 2015-07-03 19:36:20 | Re: Help with 'contestant' query |
Previous Message | David G. Johnston | 2015-07-01 12:17:48 | Re: [C#] File Upload to PostgreSQL |