Skip to content

37.24.element_types#

视图element_types包含数组元素的数据类型描述符。当表列、复合类型属性、域、函数参数或函数返回值被定义为数组类型时,相应的模式视图仅在列data_type中包含ARRAY。若要获取数组元素类型的信息,可以将相应的视图与该视图联接。例如,若要显示表中的列(如有)的数据类型和数组元素类型,可以执行以下操作:

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;

此视图仅包括当前用户有权访问的对象,即用户是所有者或拥有某些权限。

表 37.22.element_types

列类型

说明

object_catalog sql_identifier

包含使用所述数组的对象的数据库的名称(始终为当前数据库)

object_schema sql_identifier

包含使用所述数组的对象的模式的名称

object_name sql_identifier

使用所述数组的对象的名称

object_type character_data

使用所述数组的对象的类型:TABLE(该表的一列使用该数组)、USER-DEFINED TYPE(该复合类型的一个属性使用该数组)、DOMAIN(该域使用该数组)、ROUTINE(该函数的参数或返回数据类型使用该数组)之一。

collection_type_identifier sql_identifier

所述数组的数据类型描述符的标识符。使用此标识符可与其他信息模式视图的 dtd_identifier 列联接。

data_type character_data

数组元素的数据类型,如果它是一个内置类型,否则为 USER-DEFINED(在这种情况下,类型在 udt_name 和关联列中标识)。

character_maximum_length cardinal_number

始终为 null,因为此信息不适用于 PostgreSQL 中的数组元素数据类型

character_octet_length cardinal_number

始终为 null,因为此信息不适用于 PostgreSQL 中的数组元素数据类型

character_set_catalog sql_identifier

适用于 PostgreSQL 中不可用的功能

character_set_schema sql_identifier

适用于 PostgreSQL 中不可用的功能

character_set_name sql_identifier

适用于 PostgreSQL 中不可用的功能

collation_catalog sql_identifier

包含元素类型校对的数据库的名称(始终为当前数据库),如果为默认值或元素的数据类型不可校对,则为 null

collation_schema sql_identifier

包含元素类型校对的架构的名称,如果为默认值或元素的数据类型不可校对,则为 null

collation_name sql_identifier

元素类型的校对名称,如果为默认值或元素的数据类型不可校对,则为 null

numeric_precision cardinal_number

始终为 null,因为此信息不适用于 PostgreSQL 中的数组元素数据类型

numeric_precision_radix cardinal_number

始终为 null,因为此信息不适用于 PostgreSQL 中的数组元素数据类型

numeric_scale cardinal_number

始终为 null,因为此信息不适用于 PostgreSQL 中的数组元素数据类型

datetime_precision cardinal_number

始终为 null,因为此信息不适用于 PostgreSQL 中的数组元素数据类型

interval_type character_data

始终为 null,因为此信息不适用于 PostgreSQL 中的数组元素数据类型

interval_precision cardinal_number

始终为 null,因为此信息不适用于 PostgreSQL 中的数组元素数据类型

domain_default character_data

尚未实现

udt_catalog sql_identifier

定义元素数据类型的数据库的名称(始终为当前数据库)

udt_schema sql_identifier

定义元素数据类型的架构的名称

udt_name sql_identifier

元素的数据类型的名称

scope_catalog sql_identifier

适用于 PostgreSQL 中不可用的功能

scope_schema sql_identifier

适用于 PostgreSQL 中不可用的功能

scope_name sql_identifier

适用于 PostgreSQL 中不可用的功能

maximum_cardinality cardinal_number

始终为 null,因为在 PostgreSQL 中,数组始终具有无限的最大基数

dtd_identifier sql_identifier

元素的数据类型描述符的标识符。这目前没有用。