Re: disabling an index without deleting it?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



2008/2/27, Scott Marlowe <scott.marlowe@xxxxxxxxx>:
> On Tue, Feb 26, 2008 at 10:48 PM, Tom Lane <tgl@xxxxxxxxxxxxx> wrote:
>  > "Markus Bertheau" <mbertheau.pg@xxxxxxxxxxxxxx> writes:
>  >  > 2008/2/27, Tom Lane <tgl@xxxxxxxxxxxxx>:
>  >
>  > >> No, what makes you think that?  The index won't change at all in the
>  >  >> above example.  The major problem is, as Scott says, that DROP INDEX
>  >  >> takes exclusive lock on the table so any other sessions will be locked
>  >  >> out of it for the duration of your test query.
>  >
>  >  > Why is the exclusive lock not taken later, so that this method can be
>  >  > used reasonably risk-free on production systems?
>  >
>  >  Er, later than what?  Once the DROP is pending, other transactions can
>  >  hardly safely use the index for lookups, and what should they do about
>  >  insertions?
>
>
> I see what you're saying.  Sadly, my dreams of drop index concurrently
>  appear dashed.

Maybe a different syntax: DROP INDEX DEFERRED, which will make the
current transaction behave as if the index was dropped but not
actually drop it until the end of the transaction. Inserts and updates
of this and other transactions behave as if the index existed.

On the other hand, if the only reason to have that feature is to plan
and execute queries pretending that one index doesn't exist, then DROP
INDEX DEFERRED is not the most straightforward syntax.

Markus

-- 
Markus Bertheau
Blog: http://www.bluetwanger.de/blog/

---------------------------(end of broadcast)---------------------------
TIP 3: Have you checked our extensive FAQ?

               http://www.postgresql.org/docs/faq

[Postgresql General]     [Postgresql PHP]     [PHP Users]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Yosemite]

  Powered by Linux