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:09 +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 3f13991779050ff9d8796cc071ced747ecc8dee6..b337f2ee55586a30f62de8706e49c9aa2feef8dc 100644 (file)
@@ -594,6 +594,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 f4b7343daced66e12cd08fb856f91fa869897cce..d950bd930021122fc7f608eb61aeb7550e5007d2 100644 (file)
@@ -789,6 +789,11 @@ find_relation_notnullatts(PlannerInfo *root, Oid relid)
  * 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)