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

From Etsuro Fujita
Subject Re: inherit support for foreign tables
Date
Msg-id 547D2B1D.1080107@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  (Ashutosh Bapat <ashutosh.bapat@enterprisedb.com>)
List pgsql-hackers
(2014/11/28 18:14), Ashutosh Bapat wrote:
> On Thu, Nov 27, 2014 at 3:52 PM, Etsuro Fujita
> <fujita.etsuro@lab.ntt.co.jp <mailto:fujita.etsuro@lab.ntt.co.jp>> wrote:
>     Apart from the above, I noticed that the patch doesn't consider to
>     call ExplainForeignModify during EXPLAIN for an inherited
>     UPDATE/DELETE, as shown below (note that there are no UPDATE remote
>     queries displayed):

>     So, I'd like to modify explain.c to show those queries like this:

>     postgres=# explain verbose update parent set a = a * 2 where a = 5;
>                                           QUERY PLAN
>     ------------------------------__------------------------------__-------------------------
>       Update on public.parent  (cost=0.00..280.77 rows=25 width=10)
>         ->  Seq Scan on public.parent  (cost=0.00..0.00 rows=1 width=10)
>               Output: (parent.a * 2), parent.ctid
>               Filter: (parent.a = 5)
>         Remote SQL: UPDATE public.mytable_1 SET a = $2 WHERE ctid = $1
>         ->  Foreign Scan 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
>         Remote SQL: UPDATE public.mytable_2 SET a = $2 WHERE ctid = $1
>         ->  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)

> Two "remote SQL" under a single node would be confusing. Also the node
> is labelled as "Foreign Scan". It would be confusing to show an "UPDATE"
> command under this "scan" node.

I thought this as an extention of the existing (ie, non-inherited) case 
(see the below example) to the inherited case.

postgres=# explain verbose update ft1 set a = a * 2 where a = 5;                                     QUERY PLAN
------------------------------------------------------------------------------------- Update on public.ft1
(cost=100.00..140.38rows=12 width=10)   Remote SQL: UPDATE public.mytable_1 SET a = $2 WHERE ctid = $1   ->  Foreign
Scanon public.ft1  (cost=100.00..140.38 rows=12 width=10)         Output: (a * 2), ctid         Remote SQL: SELECT a,
ctidFROM public.mytable_1 WHERE ((a = 
 
5)) FOR UPDATE
(5 rows)

I think we should show update commands somewhere for the inherited case 
as for the non-inherited case.  Alternatives to this are welcome.

> BTW, I was experimenting with DMLs being executed on multiple FDW server
> under same transaction and found that the transactions may not be atomic
> (and may be inconsistent), if one or more of the server fails to commit
> while rest of them commit the transaction. The reason for this is, we do
> not "rollback" the already "committed" changes to the foreign server, if
> one or more of them fail to "commit" a transaction. With foreign tables
> under inheritance hierarchy a single DML can span across multiple
> servers and the result may not be atomic (and may be inconsistent). So,

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
succeedsand the local one 
 
fails, for example, resulting in data inconsistency between the local 
and the remote.

> either we have to disable DMLs on an inheritance hierarchy which spans
> multiple servers. OR make sure that such transactions follow 2PC norms.

-1 for disabling update queries on such an inheritance hierarchy because 
I think we should leave that to the user's judgment.  And I think 2PC is 
definitely a separate patch.

Thanks,

Best regards,
Etsuro Fujita



pgsql-hackers by date:

Previous
From: Craig Ringer
Date:
Subject: Re: [Windows,PATCH] Use faster, higher precision timer API
Next
From: Jeff Davis
Date:
Subject: Re: 9.5: Better memory accounting, towards memory-bounded HashAgg