Re: inherit support for foreign tables - Mailing list pgsql-hackers

From Etsuro Fujita
Subject Re: inherit support for foreign tables
Date
Msg-id 547FD69A.8090308@lab.ntt.co.jp
Whole thread Raw
In response to Re: inherit support for foreign tables  (Ashutosh Bapat <ashutosh.bapat@enterprisedb.com>)
Responses Re: inherit support for foreign tables
Re: inherit support for foreign tables
List pgsql-hackers
(2014/12/03 19:35), Ashutosh Bapat wrote:
> On Tue, Dec 2, 2014 at 8:29 AM, Etsuro Fujita
> <fujita.etsuro@lab.ntt.co.jp <mailto:fujita.etsuro@lab.ntt.co.jp>> wrote:

> This is not exactly extension of non-inheritance case. non-inheritance
> case doesn't show two remote SQLs under the same plan node. May be you
> can rename the label Remote SQL as Remote UPDATE/INSERT/DELETE (or
> something to that effect) for the DML command and the Foreign plan node
> should be renamed to Foreign access node or something to indicate that
> it does both the scan as well as DML. I am not keen about the actual
> terminology, but I think a reader of plan shouldn't get confused.
>
> We can leave this for committer's judgement.

Thanks for the proposal!  I think that would be a good idea.  But I 
think there would be another idea.  An example will be shown below.  We 
show the update commands below the ModifyTable node, not above the 
corresponding ForeignScan nodes, so maybe less confusing.  If there are 
no objections of you and others, I'll update the patch this way.

postgres=# explain verbose update parent set a = a * 2 where a = 5;                                     QUERY PLAN
------------------------------------------------------------------------------------- Update on public.parent
(cost=0.00..280.77rows=25 width=10)   On public.ft1     Remote SQL: UPDATE public.mytable_1 SET a = $2 WHERE ctid = $1
On public.ft2     Remote SQL: UPDATE public.mytable_2 SET a = $2 WHERE ctid = $1   ->  Seq Scan on public.parent
(cost=0.00..0.00rows=1 width=10)         Output: (parent.a * 2), parent.ctid         Filter: (parent.a = 5)   ->
ForeignScan on public.ft1  (cost=100.00..140.38 rows=12 width=10)         Output: (ft1.a * 2), ft1.ctid         Remote
SQL:SELECT a, ctid FROM public.mytable_1 WHERE ((a = 
 
5)) FOR UPDATE   ->  Foreign Scan on public.ft2  (cost=100.00..140.38 rows=12 width=10)         Output: (ft2.a * 2),
ft2.ctid        Remote SQL: SELECT a, ctid FROM public.mytable_2 WHERE ((a = 
 
5)) FOR UPDATE
(12 rows)

>     IIUC, even the transactions over the local and the *single* remote
>     server are not guaranteed to be executed atomically in the current
>     form.  It is possible that the remote transaction succeeds and the
>     local one fails, for example, resulting in data inconsistency
>     between the local and the remote.

> IIUC, while committing transactions involving a single remote server,
> the steps taken are as follows
> 1. the local changes are brought to PRE-COMMIT stage, which means that
> the transaction *will* succeed locally after successful completion of
> this phase,
> 2. COMMIT message is sent to the foreign server
> 3. If step two succeeds, local changes are committed and successful
> commit is conveyed to the client
> 4. if step two fails, local changes are rolled back and abort status is
> conveyed to the client
> 5. If step 1 itself fails, the remote changes are rolled back.
> This is as per one phase commit protocol which guarantees ACID for
> single foreign data source. So, the changes involving local and a single
> foreign server seem to be atomic and consistent.

Really?  Maybe I'm missing something, but I don't think the current 
implementation for committing transactions has such a mechanism stated 
in step 1.  So, I think it's possible that the local transaction fails 
in step3 while the remote transaction succeeds, as mentioned above.

Thanks,

Best regards,
Etsuro Fujita



pgsql-hackers by date:

Previous
From: Simon Riggs
Date:
Subject: Re: Removing INNER JOINs
Next
From: Simon Riggs
Date:
Subject: Re: tracking commit timestamps