Commit 1c7a0b38 authored by Alvaro Herrera's avatar Alvaro Herrera

Add missing break out seqscan loop in logical replication

When replica identity is FULL (an admittedly unusual case), the loop
that searches for tuples in execReplication.c didn't stop scanning the
table when once a matching tuple was found.  Add the missing 'break'.

Note slight behavior change: we now return the first matching tuple
rather than the last one.  They are supposed to be indistinguishable
anyway, so this shouldn't matter.

Author: Konstantin Knizhnik
Discussion: https://postgr.es/m/379743f6-ae91-b866-f7a2-5624e6d2b0a4@postgrespro.ru
parent f1f10a1b
...@@ -327,6 +327,9 @@ retry: ...@@ -327,6 +327,9 @@ retry:
XactLockTableWait(xwait, NULL, NULL, XLTW_None); XactLockTableWait(xwait, NULL, NULL, XLTW_None);
goto retry; goto retry;
} }
/* Found our tuple and it's not locked */
break;
} }
/* Found tuple, try to lock it in the lockmode. */ /* Found tuple, try to lock it in the lockmode. */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment