Postgresql 中文操作指南
37.24. 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;
此视图仅包含当前用户有权访问的对象,通过所有者或具有一定权限。
Table 37.22. element_types Columns
Column Type Description |
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 Not yet implemented |
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 元素的数据类型描述符的标识符。目前此标识符无用。 |