summaryrefslogtreecommitdiff
path: root/contrib/btree_gist/sql/timetz.sql
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2025-06-20 13:41:11 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2025-06-20 13:41:11 -0400
commit75b8982eae78f930cc8c1c48cd2d9dc03113d92b (patch)
tree6ce4e2e8ba26f1cf4d05d5808fcb5fce5711c9a5 /contrib/btree_gist/sql/timetz.sql
parentfc0fb77c550fe8289d718c33c7aacf16023d9941 (diff)
Use SnapshotDirty when checking for conflicting index names.
While choosing an autogenerated name for an index, look for pre-existing relations using a SnapshotDirty snapshot, instead of the previous behavior that considered only committed-good pg_class rows. This allows us to detect and avoid conflicts against indexes that are still being built. It's still possible to fail due to a race condition, but the window is now just the amount of time that it takes DefineIndex to validate all its parameters, call smgrcreate(), and enter the index's pg_class row. Formerly the race window covered the entire time needed to create and fill an index, which could be very long if the table is large. Worse, if the conflicting index creation is part of a larger transaction, it wouldn't be visible till COMMIT. So this isn't a complete solution, but it should greatly ameliorate the problem, and the patch is simple enough to be back-patchable. It might at some point be useful to do the same for pg_constraint entries (cf. ChooseConstraintName, ConstraintNameExists, and related functions). However, in the absence of field complaints, I'll leave that alone for now. The relation-name test should be good enough for index-based constraints, while foreign-key constraints seem to be okay since they require exclusive locks to create. Bug: #18959 Reported-by: Maximilian Chrzan <maximilian.chrzan@here.com> Author: Tom Lane <tgl@sss.pgh.pa.us> Reviewed-by: Dilip Kumar <dilipbalaut@gmail.com> Discussion: https://postgr.es/m/18959-f63b53b864bb1417@postgresql.org Backpatch-through: 13
Diffstat (limited to 'contrib/btree_gist/sql/timetz.sql')
0 files changed, 0 insertions, 0 deletions