]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
Doc: cover index CONCURRENTLY causing errors in INSERT ... ON CONFLICT.
authorNoah Misch <noah@leadboat.com>
Mon, 3 Nov 2025 20:57:09 +0000 (12:57 -0800)
committerNoah Misch <noah@leadboat.com>
Mon, 3 Nov 2025 20:57:14 +0000 (12:57 -0800)
Author: Mikhail Nikalayeu <mihailnikalayeu@gmail.com>
Reviewed-by: Noah Misch <noah@leadboat.com>
Discussion: https://postgr.es/m/CANtu0ojXmqjmEzp-=aJSxjsdE76iAsRgHBoK0QtYHimb_mEfsg@mail.gmail.com
Backpatch-through: 13

doc/src/sgml/ref/insert.sgml
src/backend/optimizer/util/plancat.c

index 1aa7a7ecbac60dbed3163a0e064435c2e7b64146..1c358b984ae2abc8879f6b5fc3aaca2135ae8b2b 100644 (file)
@@ -556,6 +556,15 @@ INSERT INTO <replaceable class="parameter">table_name</replaceable> [ AS <replac
     </para>
    </tip>
 
+   <warning>
+    <para>
+      While <command>CREATE INDEX CONCURRENTLY</command> or <command>REINDEX
+      CONCURRENTLY</command> is running on a unique index, <command>INSERT
+      ... ON CONFLICT</command> statements on the same table may unexpectedly
+      fail with a unique violation.
+    </para>
+   </warning>
+
   </refsect2>
  </refsect1>
 
index 3b1ada1127e87409a344364c1232e705332581ac..47169e81d12947e653a010c7ceb1453ede23c7f1 100644 (file)
@@ -627,6 +627,11 @@ get_relation_foreign_keys(PlannerInfo *root, RelOptInfo *rel,
  * the purposes of inference.  If no opclass (or collation) is specified, then
  * all matching indexes (that may or may not match the default in terms of
  * each attribute opclass/collation) are used for inference.
+ *
+ * Note: during index CONCURRENTLY operations, different transactions may
+ * reference different sets of arbiter indexes. This can lead to false unique
+ * constraint violations that wouldn't occur during normal operations.  For
+ * more information, see insert.sgml.
  */
 List *
 infer_arbiter_indexes(PlannerInfo *root)