От: Alvaro Herrera
Тема: Re: MVCC & indexes?
Дата: ,
Msg-id: 20061031223632.GG12008@alvh.no-ip.org
(см: обсуждение, исходный текст)
Ответ на: MVCC & indexes?  (Ivan Voras)
Ответы: Re: MVCC & indexes?  (Ivan Voras)
Список: pgsql-performance

Скрыть дерево обсуждения

MVCC & indexes?  (Ivan Voras, )
 Re: MVCC & indexes?  (Alvaro Herrera, )
  Re: MVCC & indexes?  (Ivan Voras, )
 Re: MVCC & indexes?  (, )

Ivan Voras wrote:
> Ok, so MVCC is the best thing since a guy put a round stone on a stick
> and called it "the wheel", but I've seen several references on this list
> about "indexes not being under MVCC" - at least that's how I read it,
> the original posts were explaining why indexes can't be used for solving
> MIN()/MAX()/COUNT() aggregates. Is this correct?
> In particular, I'm trying to find out is there (b)locking involved when
> concurrently updating and/or inserting records in an indexed table. My
> guess is that, since PG does copy+delete on updating, even updating a
> non-indexed field will require fixups in the index tree (to point to the
> new record) and thus (b)locking.

Well, there certainly is locking involved in inserting index entries,
but it's more fine-grained than you seem to think.  Only one page of the
index is locked at any time, resulting in that typically there's very
little blocking involved.  Two processes can be inserting into the same
index concurrently (btree and GiST indexes at least; GiST only gained
concurrency in a recent release, I don't remember if it was 8.0 or 8.1).

Alvaro Herrera                                http://www.CommandPrompt.com/
The PostgreSQL Company - Command Prompt, Inc.

В списке pgsql-performance по дате сообщения:

От: Tom Lane
Сообщение: Re: Help w/speeding up range queries?
От: "Luke Lonergan"
Сообщение: Re: Help w/speeding up range queries?