pgsql: Remove unnecessary checks for indexes for REPLICA IDENTITY FULL

From: Masahiko Sawada <msawada(at)postgresql(dot)org>
To: pgsql-committers(at)lists(dot)postgresql(dot)org
Subject: pgsql: Remove unnecessary checks for indexes for REPLICA IDENTITY FULL
Date: 2023-07-25 06:13:14
Message-ID: E1qOBIH-001EU1-GU@gemulon.postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-committers

Remove unnecessary checks for indexes for REPLICA IDENTITY FULL tables.

Previously, when selecting an usable index for update/delete for the
REPLICA IDENTITY FULL table, in IsIndexOnlyExpression(), we used to
check if all index fields are not expressions. However, it was not
necessary, because it is enough to check if only the leftmost index
field is not an expression (and references the remote table column)
and this check has already been done by
RemoteRelContainsLeftMostColumnOnIdx().

This commit removes IsIndexOnlyExpression() and
RemoteRelContainsLeftMostColumnOnIdx() and all checks for usable
indexes for REPLICA IDENTITY FULL tables are now performed by
IsIndexUsableForReplicaIdentityFull().

Backpatch this to remain the code consistent.

Reported-by: Peter Smith
Reviewed-by: Amit Kapila, Önder Kalacı
Discussion: https://postgr.es/m/CAHut%2BPsGRE5WSsY0jcLHJEoA17MrbP9yy8FxdjC_ZOAACxbt%2BQ%40mail.gmail.com
Backpatch-through: 16

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/d0ce9d0bc7f6aab6e45158bfa4f19cffdd7079a6

Modified Files
--------------
src/backend/executor/execReplication.c | 9 ---
src/backend/replication/logical/relation.c | 118 +++++++++++------------------
src/backend/replication/logical/worker.c | 24 ++++--
src/include/replication/logicalrelation.h | 2 +-
4 files changed, 64 insertions(+), 89 deletions(-)

Browse pgsql-committers by date

  From Date Subject
Next Message Amit Kapila 2023-07-25 07:13:29 pgsql: Fix code indentation vioaltion introduced in commit d38ad8e31d.
Previous Message Masahiko Sawada 2023-07-25 06:13:07 pgsql: Remove unnecessary checks for indexes for REPLICA IDENTITY FULL