36.24. element_types

The view element_types contains the data type descriptors of the elements of arrays. When a table column, composite-type attribute, domain, function parameter, or function return value is defined to be of an array type, the respective information schema view only contains ARRAY in the column data_type. To obtain information on the element type of the array, you can join the respective view with this view. For example, to show the columns of a table with data types and array element types, if applicable, you could do:

 SELECT c.column_name, c.data_type, e.data_type AS element_type FROM information_schema.columns c LEFT JOIN information_schema.element_types e ON ((c.table_catalog, c.table_schema, c.table_name, 'TABLE', c.dtd_identifier) = (e.object_catalog, e.object_schema, e.object_name, e.object_type, e.collection_type_identifier)) WHERE c.table_schema = '...' AND c.table_name = '...' ORDER BY c.ordinal_position; 

This view only includes objects that the current user has access to, by way of being the owner or having some privilege.

Table 36.22. element_types Columns

Column Type

Description

object_catalogsql_identifier

Name of the database that contains the object that uses the array being described (always the current database)

object_schemasql_identifier

Name of the schema that contains the object that uses the array being described

object_namesql_identifier

Name of the object that uses the array being described

object_typecharacter_data

The type of the object that uses the array being described: one of TABLE (the array is used by a column of that table), USER-DEFINED TYPE (the array is used by an attribute of that composite type), DOMAIN (the array is used by that domain), ROUTINE (the array is used by a parameter or the return data type of that function).

collection_type_identifiersql_identifier

The identifier of the data type descriptor of the array being described. Use this to join with the dtd_identifier columns of other information schema views.

data_typecharacter_data

Data type of the array elements, if it is a built-in type, else USER-DEFINED (in that case, the type is identified in udt_name and associated columns).

character_maximum_lengthcardinal_number

Always null, since this information is not applied to array element data types in Postgres Pro

character_octet_lengthcardinal_number

Always null, since this information is not applied to array element data types in Postgres Pro

character_set_catalogsql_identifier

Applies to a feature not available in Postgres Pro

character_set_schemasql_identifier

Applies to a feature not available in Postgres Pro

character_set_namesql_identifier

Applies to a feature not available in Postgres Pro

collation_catalogsql_identifier

Name of the database containing the collation of the element type (always the current database), null if default or the data type of the element is not collatable

collation_schemasql_identifier

Name of the schema containing the collation of the element type, null if default or the data type of the element is not collatable

collation_namesql_identifier

Name of the collation of the element type, null if default or the data type of the element is not collatable

numeric_precisioncardinal_number

Always null, since this information is not applied to array element data types in Postgres Pro

numeric_precision_radixcardinal_number

Always null, since this information is not applied to array element data types in Postgres Pro

numeric_scalecardinal_number

Always null, since this information is not applied to array element data types in Postgres Pro

datetime_precisioncardinal_number

Always null, since this information is not applied to array element data types in Postgres Pro

interval_typecharacter_data

Always null, since this information is not applied to array element data types in Postgres Pro

interval_precisioncardinal_number

Always null, since this information is not applied to array element data types in Postgres Pro

domain_defaultcharacter_data

Not yet implemented

udt_catalogsql_identifier

Name of the database that the data type of the elements is defined in (always the current database)

udt_schemasql_identifier

Name of the schema that the data type of the elements is defined in

udt_namesql_identifier

Name of the data type of the elements

scope_catalogsql_identifier

Applies to a feature not available in Postgres Pro

scope_schemasql_identifier

Applies to a feature not available in Postgres Pro

scope_namesql_identifier

Applies to a feature not available in Postgres Pro

maximum_cardinalitycardinal_number

Always null, because arrays always have unlimited maximum cardinality in Postgres Pro

dtd_identifiersql_identifier

An identifier of the data type descriptor of the element. This is currently not useful.


close