diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2012-09-18 00:31:40 -0400 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2012-09-18 00:31:40 -0400 |
commit | 3f828fae6221d93cbef370f57ab3f234b590ca98 (patch) | |
tree | d6227b947409dfd6fb04eb78209f5334f7da4852 /src/backend/utils/adt | |
parent | bcf90cc18b5d8567f2cd4f789a047eb009fa15ec (diff) | |
download | postgresql-3f828fae6221d93cbef370f57ab3f234b590ca98.tar.gz postgresql-3f828fae6221d93cbef370f57ab3f234b590ca98.zip |
Fix array_typanalyze to work for domains over arrays.
Not sure how we missed this case, but we did. Per bug #7551 from
Diego de Lima.
Diffstat (limited to 'src/backend/utils/adt')
-rw-r--r-- | src/backend/utils/adt/array_typanalyze.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/src/backend/utils/adt/array_typanalyze.c b/src/backend/utils/adt/array_typanalyze.c index 604b86ca644..e4c94086bca 100644 --- a/src/backend/utils/adt/array_typanalyze.c +++ b/src/backend/utils/adt/array_typanalyze.c @@ -19,6 +19,7 @@ #include "commands/vacuum.h" #include "utils/array.h" #include "utils/datum.h" +#include "utils/lsyscache.h" #include "utils/typcache.h" @@ -108,11 +109,10 @@ array_typanalyze(PG_FUNCTION_ARGS) PG_RETURN_BOOL(false); /* - * Check attribute data type is a varlena array. + * Check attribute data type is a varlena array (or a domain over one). */ - element_typeid = stats->attrtype->typelem; - - if (!OidIsValid(element_typeid) || stats->attrtype->typlen != -1) + element_typeid = get_base_element_type(stats->attrtypid); + if (!OidIsValid(element_typeid)) elog(ERROR, "array_typanalyze was invoked for non-array type %u", stats->attrtypid); |