Re: row filtering for logical replication - Mailing list pgsql-hackers

From Euler Taveira
Subject Re: row filtering for logical replication
Date
Msg-id 5b9fceed-8f91-467f-a64e-2134c5c3f496@www.fastmail.com
Whole thread Raw
In response to Re: row filtering for logical replication  (japin <japinli@hotmail.com>)
Responses Re: row filtering for logical replication
Re: row filtering for logical replication
List pgsql-hackers
On Mon, Feb 1, 2021, at 6:11 AM, japin wrote:
Thanks for updating the patch.  Here are some comments:
Thanks for your review. I updated the documentation accordingly.

The documentation says:

>  Columns used in the <literal>WHERE</literal> clause must be part of the
>  primary key or be covered by <literal>REPLICA IDENTITY</literal> otherwise
>  <command>UPDATE</command> and <command>DELETE</command> operations will not
>  be replicated.
The UPDATE is an oversight from a previous version.


Does the publication only load the REPLICA IDENTITY columns into oldtuple when we
execute DELETE? So the pgoutput_row_filter() cannot find non REPLICA IDENTITY
columns, which cause it return false, right?  If that's right, the UPDATE might
not be limitation by REPLICA IDENTITY, because all columns are in newtuple,
isn't it?
No. oldtuple could possibly be available for UPDATE and DELETE. However, row
filter consider only one tuple for filtering. INSERT has only newtuple; row
filter uses it.  UPDATE has newtuple and optionally oldtuple (if it has PK or
REPLICA IDENTITY); row filter uses newtuple. DELETE optionally has only
oldtuple; row filter uses it (if available). Keep in mind, if the expression
evaluates to NULL, it returns false and the row won't be replicated.

After the commit 3696a600e2, the last patch does not apply cleanly. I'm
attaching another version to address the documentation issues.


--
Euler Taveira

Attachment

pgsql-hackers by date:

Previous
From: Andres Freund
Date:
Subject: Re: Fix DROP TABLESPACE on Windows with ProcSignalBarrier?
Next
From: "Joel Jacobson"
Date:
Subject: Re: Recording foreign key relationships for the system catalogs