ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
# 34.23\. `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; ``` 这个视图只包含当前用户具有权限访问的对象,通过成为其所有者或者有些权限。 **Table 34-21\. `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里的数组元素数据类型 | | `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` | 总是空,因为这个信息并不适用于PostgreSQL里的数组元素数据类型 | | `dtd_identifier` | `sql_identifier` | 元素的数据类型描述符的标识符。目前没什么用处。 |