mirror of
https://github.com/postgres/postgres.git
synced 2025-10-24 01:29:19 +03:00
Coercion sanity check in ri_HashCompareOp failed to allow for enums, as per
example from Rod Taylor. On reflection the correct test here is for any polymorphic type, not specifically ANYARRAY as in the original coding.
This commit is contained in:
@@ -8,7 +8,7 @@
|
||||
*
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/src/backend/commands/tablecmds.c,v 1.254 2008/05/16 23:36:04 tgl Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/commands/tablecmds.c,v 1.255 2008/05/19 04:14:24 tgl Exp $
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@@ -4377,11 +4377,11 @@ ATAddForeignKeyConstraint(AlteredTableInfo *tab, Relation rel,
|
||||
/*
|
||||
* Otherwise, look for an implicit cast from the FK type to the
|
||||
* opcintype, and if found, use the primary equality operator.
|
||||
* This is a bit tricky because opcintype might be a generic type
|
||||
* such as ANYARRAY, and so what we have to test is whether the
|
||||
* two actual column types can be concurrently cast to that type.
|
||||
* (Otherwise, we'd fail to reject combinations such as int[] and
|
||||
* point[].)
|
||||
* This is a bit tricky because opcintype might be a polymorphic
|
||||
* type such as ANYARRAY or ANYENUM; so what we have to test is
|
||||
* whether the two actual column types can be concurrently cast to
|
||||
* that type. (Otherwise, we'd fail to reject combinations such
|
||||
* as int[] and point[].)
|
||||
*/
|
||||
Oid input_typeids[2];
|
||||
Oid target_typeids[2];
|
||||
|
Reference in New Issue
Block a user