Will partial index creation use existing index? - Mailing list pgsql-general

From Steve Crawford
Subject Will partial index creation use existing index?
Date
Msg-id 469E833C.4000401@pinpointresearch.com
Whole thread Raw
Responses Re: Will partial index creation use existing index?
Re: Will partial index creation use existing index?
List pgsql-general
Does PostgreSQL use an existing index, if possible, when creating a
partial index?

By way of background, we have some nightly bulk processing that includes
a couple of 15-30 million row tables. Most of the processing is only
looking at prior-day data (up to ~200,000 rows) and for efficiency
requires several indexes. Except for this one process, the indexes are
useless and I'd rather not constantly maintain them.

There is an index on the timestamp column so I have considered creating
the indexes on a temporary basis with something like:
create index foo_bar on foo (bar)
  where timestamp_col > current_date - interval '1 day';

(Yes this is simplified, I am aware of the Daylight Saving Time
off-by-an-hour implications.)

It seems that creating this partial index would be more efficient if the
existing index were used but "explain create index..." just gives me an
error and the query seems to run way too long to be processing only the
one day data. For comparison, on a relatively large 225,000 row day I
can create temporary table ondeay... on the same criteria and create 10
indexes and analyze the table in well under 10 seconds which is way
faster than creating even a single partial index on the full table.

Cheers,
Steve


pgsql-general by date:

Previous
From: Michael Glaesemann
Date:
Subject: Re: Need help optimizing this query
Next
From: Gregory Stark
Date:
Subject: Re: Update of table lags execution of statement by >1 minute?