Commit 63e98b55 authored by Tom Lane's avatar Tom Lane

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.
parent 2dad10f4
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * 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, ...@@ -4377,11 +4377,11 @@ ATAddForeignKeyConstraint(AlteredTableInfo *tab, Relation rel,
/* /*
* Otherwise, look for an implicit cast from the FK type to the * Otherwise, look for an implicit cast from the FK type to the
* opcintype, and if found, use the primary equality operator. * opcintype, and if found, use the primary equality operator.
* This is a bit tricky because opcintype might be a generic type * This is a bit tricky because opcintype might be a polymorphic
* such as ANYARRAY, and so what we have to test is whether the * type such as ANYARRAY or ANYENUM; so what we have to test is
* two actual column types can be concurrently cast to that type. * whether the two actual column types can be concurrently cast to
* (Otherwise, we'd fail to reject combinations such as int[] and * that type. (Otherwise, we'd fail to reject combinations such
* point[].) * as int[] and point[].)
*/ */
Oid input_typeids[2]; Oid input_typeids[2];
Oid target_typeids[2]; Oid target_typeids[2];
......
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
* *
* Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
* *
* $PostgreSQL: pgsql/src/backend/utils/adt/ri_triggers.c,v 1.108 2008/05/12 20:02:02 alvherre Exp $ * $PostgreSQL: pgsql/src/backend/utils/adt/ri_triggers.c,v 1.109 2008/05/19 04:14:24 tgl Exp $
* *
* ---------- * ----------
*/ */
...@@ -3938,8 +3938,12 @@ ri_HashCompareOp(Oid eq_opr, Oid typeid) ...@@ -3938,8 +3938,12 @@ ri_HashCompareOp(Oid eq_opr, Oid typeid)
if (pathtype != COERCION_PATH_FUNC && if (pathtype != COERCION_PATH_FUNC &&
pathtype != COERCION_PATH_RELABELTYPE) pathtype != COERCION_PATH_RELABELTYPE)
{ {
/* If target is ANYARRAY, assume it's OK, else punt. */ /*
if (lefttype != ANYARRAYOID) * The declared input type of the eq_opr might be a
* polymorphic type such as ANYARRAY or ANYENUM. If so,
* assume the coercion is valid; otherwise complain.
*/
if (!IsPolymorphicType(lefttype))
elog(ERROR, "no conversion function from %s to %s", elog(ERROR, "no conversion function from %s to %s",
format_type_be(typeid), format_type_be(typeid),
format_type_be(lefttype)); format_type_be(lefttype));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment