2024年9月26日: PostgreSQL 17 发布!
支持版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:devel
不支持的版本:11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4

35.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;

该视图仅包含当前用户可访问的对象,例如,作为所有者或拥有某些权限。

表 35.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

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

character_octet_length cardinal_number

始终为空,因为此信息不应用于 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

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

numeric_precision_radix cardinal_number

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

numeric_scale cardinal_number

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

datetime_precision cardinal_number

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

interval_type character_data

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

interval_precision cardinal_number

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

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

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

dtd_identifier sql_identifier

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


提交更正

如果您在文档中看到任何不正确的内容,与您对特定功能的体验不符,或需要进一步澄清,请使用 此表格 报告文档问题。