Re: [Proposal] Global temporary tables

From: Konstantin Knizhnik <k(dot)knizhnik(at)postgrespro(dot)ru>
To: Pavel Stehule <pavel(dot)stehule(at)gmail(dot)com>
Cc: Robert Haas <robertmhaas(at)gmail(dot)com>, Tomas Vondra <tomas(dot)vondra(at)2ndquadrant(dot)com>, 曾文旌(义从) <wenjing(dot)zwj(at)alibaba-inc(dot)com>, PostgreSQL Hackers <pgsql-hackers(at)postgresql(dot)org>, 蔡松露(子嘉) <zijia(at)taobao(dot)com>, "Cai, Le" <le(dot)cai(at)alibaba-inc(dot)com>, 萧少聪(铁庵) <shaocong(dot)xsc(at)alibaba-inc(dot)com>
Subject: Re: [Proposal] Global temporary tables
Date: 2020-01-30 08:45:35
Message-ID: 60ad936e-23d1-a46d-2783-5652040d7dbe@postgrespro.ru
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On 29.01.2020 20:37, Pavel Stehule wrote:
>
>
> st 29. 1. 2020 v 18:21 odesílatel Konstantin Knizhnik
> <k(dot)knizhnik(at)postgrespro(dot)ru <mailto:k(dot)knizhnik(at)postgrespro(dot)ru>> napsal:
>
>
>
> On 29.01.2020 20:08, Pavel Stehule wrote:
>>
>>
>>
>> 2. Actually I do not propose some completely new approach. I
>> try to
>> provide behavior with is compatible with regular tables.
>> If you create index for regular table, then it can be used in
>> all
>> sessions, right?
>>
>>
>> I don't understand to this point. Regular tables shares data,
>> shares files. You cannot to separate it. More - you have to uses
>> relatively aggressive locks to be this operation safe.
>>
>> Nothing from these points are valid for GTT.
>
> GTT shares metadata.
> As far as them are not sharing data, then GTT are safer than
> regular table, aren't them?
> "Safer" means that we need less "aggressive" locks for them: we
> need to protect only metadata, not data itself.
>
> My point is that if we allow other sessions to access created
> indexes for regular tables, then it will be not more complex to
> support it for GTT.
> Actually "not more complex" in this case means "no extra efforts
> are needed".
>
>
> It is hard to say. I see a significant difference. When I do index on
> regular table, then I don't change a context of other processes. I
> have to wait for lock, and after I got a lock then other processes
> waiting.
>
> With GTT, I don't want to wait for others - and other processes should
> build indexes inside - without expected sequence of operations. Maybe
> it can have positive effect, but it can have negative effect too. In
> this case I prefer (in this moment) zero effect on other sessions. So
> I would to build index in my session and I don't would to wait for
> other sessions, and if it is possible other sessions doesn't need to
> interact or react on my action too. It should be independent what is
> possible. The most simple solution is request on unique usage. I
> understand so it can be not too practical. Better is allow to usage
> GTT by other tables, but the changes are invisible in other sessions
> to session reset. It is minimalistic strategy. It has not benefits for
> other sessions, but it has not negative impacts too.
>

Building regular index requires two kinds of lock:
1. You have to lock pg_class to make changes in system catalog.
2. You need to lock heap relation  to pervent concurrent updates while
building index.

GTT requires 1)  but not 2).
Once backend inserts information about new index in system catalog, all
other sessions may use it. pg_class lock prevents any race condition here.
And building index itself doesn't affect any other backends.

--
Konstantin Knizhnik
Postgres Professional: http://www.postgrespro.com
The Russian Postgres Company

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Floris Van Nee 2020-01-30 09:19:19 RE: Delaying/avoiding BTreeTupleGetNAtts() call within _bt_compare()
Previous Message Peter Geoghegan 2020-01-30 07:47:25 Re: Parallel CREATE INDEX vs DSM starvation