Split ExecUpdate and ExecDelete into reusable pieces
authorAlvaro Herrera <alvherre@alvh.no-ip.org>
Thu, 17 Mar 2022 10:47:04 +0000 (11:47 +0100)
committerAlvaro Herrera <alvherre@alvh.no-ip.org>
Thu, 17 Mar 2022 10:47:04 +0000 (11:47 +0100)
commit25e777cf8e547d7423d2e1e9da71f98b9414d59e
treee6696241a9d8e21fe0a419572cf8b8aab43fd690
parentf2553d43060edb210b36c63187d52a632448e1d2
Split ExecUpdate and ExecDelete into reusable pieces

Create subroutines ExecUpdatePrologue / ExecUpdateAct /
ExecUpdateEpilogue, and similar for ExecDelete.

Introduce a new struct to be used internally in nodeModifyTable.c,
dubbed ModifyTableContext, which contains all context information needed
to perform these operations, as well as ExecInsert and others.

This allows using a different schedule and a different way of evaluating
the results of these operations, which can be exploited by a later
commit introducing support for MERGE.  It also makes ExecUpdate and
ExecDelete proper shorter and (hopefully) simpler.

Author: Álvaro Herrera <alvherre@alvh.no-ip.org>
Reviewed-by: Amit Langote <amitlangote09@gmail.com>
Reviewed-by: Japin Li <japinli@hotmail.com>
Reviewed-by: Zhihong Yu <zyu@yugabyte.com>
Discussion: https://postgr.es/m/202202271724.4z7xv3cf46kv@alvherre.pgsql
src/backend/executor/nodeModifyTable.c
src/tools/pgindent/typedefs.list