Re: disabling an index without deleting it?

Поиск
Список
Период
Сортировка
От Markus Bertheau
Тема Re: disabling an index without deleting it?
Дата
Msg-id 684362e10802262129w4fe41264p1eb75cadd5f4d259@mail.gmail.com
обсуждение исходный текст
Ответ на Re: disabling an index without deleting it?  ("Scott Marlowe" <scott.marlowe@gmail.com>)
Список pgsql-performance
2008/2/27, Scott Marlowe <scott.marlowe@gmail.com>:
> On Tue, Feb 26, 2008 at 10:48 PM, Tom Lane <tgl@sss.pgh.pa.us> wrote:
>  > "Markus Bertheau" <mbertheau.pg@googlemail.com> writes:
>  >  > 2008/2/27, Tom Lane <tgl@sss.pgh.pa.us>:
>  >
>  > >> 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/

В списке pgsql-performance по дате отправления:

Предыдущее
От: James Mansion
Дата:
Сообщение: Re: LISTEN / NOTIFY performance in 8.3
Следующее
От: "Frits Hoogland"
Дата:
Сообщение: how to identify expensive steps in an explain analyze output