From: | Nikolas Everett <nik9000(at)gmail(dot)com> |
---|---|
To: | Zach Calvert <zachcalvert(at)hemerasoftware(dot)com> |
Cc: | pgsql-performance(at)postgresql(dot)org |
Subject: | Re: Improve Query |
Date: | 2009-05-27 16:06:38 |
Message-ID: | d4e11e980905270906s79c7fa1fnd6fd8f8a5e28e8e7@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-performance |
The plan ought to be different when there are more scores and the table is
analyzed and your statistics target is high enough. At this point you don't
have enough data to merit doing anything but a seq scan. The overhead is
simply not worth it.
You could try inserting a lot more rows. I'd create a function to do
several million inserts with random numbers and then analyze and rerun.
I think in the end your probably going to see a couple of bitmap index
scans, anding the results together, and then a bitmap scan.
Keep in mind that postgres stores statistics information about each column,
but doesn't at this point store statistics about two columns together.
Preparing the query might actually hurt performance because postgres treats
a prepare as "plan this query but I'm not going to tell you value of the
parameters". If you actually let the query replan every time then you will
get a different plan for the leaderboards or score ranges that are more
popular.
On Wed, May 27, 2009 at 8:09 AM, Zach Calvert <
zachcalvert(at)hemerasoftware(dot)com> wrote:
> So Google hasn't been helpful and I'm not entirely sure what to look
> for in the mailing lists to find the answer to my problem, so here
> goes.
>
> I have a query and I have run
> explain analyze
> select count(*)
> from score
> where leaderboardid=35 and score <= 6841 and active
>
> The result is
> "Aggregate (cost=2491.06..2491.07 rows=1 width=0) (actual
> time=38.878..38.878 rows=1 loops=1)"
> " -> Seq Scan on score (cost=0.00..2391.17 rows=39954 width=0)
> (actual time=0.012..30.760 rows=38571 loops=1)"
> " Filter: (active AND (score <= 6841) AND (leaderboardid = 35))"
> "Total runtime: 38.937 ms"
>
> I have an index on score, I have an index on score and leaderboard and
> active. I can't seem to figure out how to create an index that will
> turn that "Seq Scan" into an index scan. The biggest problem is that
> the query degrades very quickly with a lot more rows and I will be
> getting A LOT MORE rows. What can I do to improve the performance of
> this query?
>
>
>
>
>
> Thank you so much,
> ZC
>
> --
> Sent via pgsql-performance mailing list (pgsql-performance(at)postgresql(dot)org)
> To make changes to your subscription:
> http://www.postgresql.org/mailpref/pgsql-performance
>
From | Date | Subject | |
---|---|---|---|
Next Message | Zach Calvert | 2009-05-27 16:25:18 | Re: Improve Query |
Previous Message | Scott Mead | 2009-05-27 16:02:47 | Re: Hosted servers with good DB disk performance? |