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 |
元素的数据类型描述符的标识符。目前没什么用处。 |