视图 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.array_type_identifier)) WHERE c.table_schema = '...' AND c.table_name = '...' ORDER BY c.ordinal_position;
这个视图只包含当前用户有权限访问的对象,也就是他是所有者或者有些 权限。
Table 31-14. element_types 字段
名字 | 数据类型 | 描述 |
---|---|---|
object_catalog | sql_identifier | 使用了被描述的数组的对象所在的数据库名称(总是当前数据库) |
object_schema | sql_identifier | 使用了被描述的数组的对象所在的模式名 |
object_name | sql_identifier | 使用了被描述的数组的对象的名字 |
object_type | character_data | 使用了被描述的数组的对象的类型:TABLE (数组被该表的一个字段使用),DOMAIN (数组被这个域使用),ROUTINE(数组被 该函数的一个参数或者返回数据类型使用)之一。 |
array_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 | 应用于一个PostgreSQL 里没有的特性 |
collation_schema | sql_identifier | 应用于一个PostgreSQL 里没有的特性 |
collation_name | sql_identifier | 应用于一个PostgreSQL 里没有的特性 |
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 | character_data | 总是空,因为这个信息并不适用于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 | 元素的数据类型描述符的标识符。这个目前没有用处。 |