summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/dialects
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2022-12-22 18:14:31 -0500
committerMike Bayer <mike_mp@zzzcomputing.com>2022-12-22 18:15:30 -0500
commit5cc18bb80077e98418b4a8066c0bc628209f3ada (patch)
tree1c6cc5c68aa2cb027565f023767b3f52c5b06a49 /lib/sqlalchemy/dialects
parentb973cbd8939f2cc0e29c668fffd507958c3e455a (diff)
downloadsqlalchemy-5cc18bb80077e98418b4a8066c0bc628209f3ada.tar.gz
expand out Index if passed to "constraint"
Fixed bug where the PostgreSQL :paramref:`_postgresql.OnConflictClause.constraint` parameter would accept an :class:`.Index` object, however would not expand this index out into its individual index expressions, instead rendering its name in an ON CONFLICT ON CONSTRAINT clause, which is not accepted by PostgreSQL; the "constraint name" form only accepts unique or exclude constraint names. The parameter continues to accept the index but now expands it out into its component expressions for the render. Fixes: #9023 Change-Id: I6baf243e26bfe578bf3f193c162dd7a623b6ede9
Diffstat (limited to 'lib/sqlalchemy/dialects')
-rw-r--r--lib/sqlalchemy/dialects/postgresql/dml.py2
1 files changed, 1 insertions, 1 deletions
diff --git a/lib/sqlalchemy/dialects/postgresql/dml.py b/lib/sqlalchemy/dialects/postgresql/dml.py
index 645bedf17..27075191d 100644
--- a/lib/sqlalchemy/dialects/postgresql/dml.py
+++ b/lib/sqlalchemy/dialects/postgresql/dml.py
@@ -213,7 +213,7 @@ class OnConflictClause(ClauseElement):
if constraint is not None:
if not isinstance(constraint, str) and isinstance(
constraint,
- (schema.Index, schema.Constraint, ext.ExcludeConstraint),
+ (schema.Constraint, ext.ExcludeConstraint),
):
constraint = getattr(constraint, "name") or constraint