Hi, On Wed, 23 Jul 2025 19:38:19 +0900 Etsuro Fujita <etsuro.fuj...@gmail.com> wrote:
> Hi, > > On Sat, Jul 19, 2025 at 12:53 AM Jehan-Guillaume de Rorthais > <j...@dalibo.com> wrote: > > […] > > Please, find in attachment the old patch forbidding more than one row to be > > deleted/updated from postgresExecForeignDelete and > > postgresExecForeignUpdate. I just rebased them without modification. I > > suppose this is much safer than leaving the FDW destroy arbitrary rows on > > the remote side based on their sole ctid. > > Thanks for rebasing the patch set, but I don't think the idea > implemented in the second patch is safe; even with the patch we have: > > […] > > The row in the partition plt_p2 is updated, which is wrong as the row > doesn't satisfy the query's WHERE condition. That's a clever test to expose the weakness of this patch… > > Or maybe we should just not support foreign table to reference a > > remote partitioned table? > > I don't think so because we can execute SELECT, INSERT, and direct > UPDATE/DELETE safely on such a foreign table. Sure, but it's still possible to create one local foreign partition pointing to remote foreign equivalent. And it seems safer considering how hard it seems to keep corruptions away from the current situation. > I think a simple fix for this is to teach the system that the foreign > table is a partitioned table; in more detail, I would like to propose > to 1) add to postgres_fdw a table option, inherited, to indicate > whether the foreign table is a partitioned/inherited table or not, and > 2) modify postgresPlanForeignModify() to throw an error if the given > operation is an update/delete on such a foreign table. Attached is a > WIP patch for that. I think it is the user's responsibility to set > the option properly, but we could modify postgresImportForeignSchema() > to support that. Also, I think this would be back-patchable. So it's just a flag the user must set to allow/disallow UPDATE/DELETE on a foreign table. I'm not convinced by this solution as users can still easily corrupt their data just because they overlooked the documentation. What about the first solution Ashutosh Bapat was suggesting: «Use WHERE CURRENT OF with cursors to update rows.» ? https://www.postgresql.org/message-id/CAFjFpRfcgwsHRmpvoOK-GUQi-n8MgAS%2BOxcQo%3DaBDn1COywmcg%40mail.gmail.com It seems to me it never has been explored, is it? Regards,