From: | Josh Berkus <josh(at)agliodbs(dot)com> |
---|---|
To: | Bruno Wolff III <bruno(at)wolff(dot)to> |
Cc: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: Two Index Questions |
Date: | 2002-07-19 17:28:18 |
Message-ID: | 200207191028.18547.josh@agliodbs.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Bruno,
> > I have two questions for my "Adventures in PostgreSQL" article reasearch:
> >
> > Multi-Column Indexes and GROUP BY:
> > Q: If you group a table by multiple colums, e.g.
> > SELECT t1.A, t1.B, t1.C, MAX(t1.G)
> > FROM t1
> > GROUP BY t1.A, t1.B, t1.C
> > Then would a multi-column index on A, B, C be faster than seperate
indexes
> > on A, B and C? I've run a few tests, but I don't have enough data in the
> > seperate tables to really get a feel for the difference.
>
> If there are lots of G entries for fixed As, Bs and Cs, then another option
> would be to have an index on all 4 tables and use a subquery with a limit 1
> clause to get the row with the max G value for any A, B and C.
We're talking about only one table, here. Not four.
I generally try to avoid using LIMIT, as it is a non-SQL92 extension. Also,
LIMIT in subqueries might someday be disallowed as it interferes with the
fundmentally unordered nature of subqueries.
--
-Josh Berkus
Aglio Database Solutions
San Francisco
From | Date | Subject | |
---|---|---|---|
Next Message | Bruce Momjian | 2002-07-19 17:29:16 | Re: [SQL] id and ID in CREATE TABLE |
Previous Message | Joseph Syjuco | 2002-07-19 17:15:42 | Re: how do i import my sql query result to a file |