返回介绍

I. 教程

II. SQL 语言

III. 服务器管理

IV. 客户端接口

V. 服务器端编程

VI. 参考手册

VII. 内部

VIII. 附录

31.16. element_types

发布于 2019-09-30 03:08:42 字数 4810 浏览 920 评论 0 收藏 0

视图 element_types 包含数组元素的数据类型的描述符。 在一个表字段,域,函数参数,或者函数返回值定义为一个数组类型的时候, 对应的信息模式视图在字段data_type 里只包含 ARRAY。 要获取数组元素类型的信息,你可以将对应的视图和这个视图连接。 比如,要用数据类型和数组元素类型显示表的字段,(如果可能),你可以用

SELECT c.column_name, c.data_type, e.data_type AS element_typeFROM 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_catalogsql_identifier使用了被描述的数组的对象所在的数据库名称(总是当前数据库)
object_schemasql_identifier使用了被描述的数组的对象所在的模式名
object_namesql_identifier使用了被描述的数组的对象的名字
object_typecharacter_data使用了被描述的数组的对象的类型:TABLE (数组被该表的一个字段使用),DOMAIN (数组被这个域使用),ROUTINE(数组被 该函数的一个参数或者返回数据类型使用)之一。
array_type_identifiersql_identifier被描述的数组的数据类型描述符标识符。用这个和其它信息模式 视图的 dtd_identifier 字段连接。
data_typecharacter_data如果这是一个内置的类型,数据元素的数据类型,否则就是 USER-DEFINED(这种情况下,类型在 udt_name 和相关的字段中标出)。
character_maximum_lengthcardinal_number总是空,因为这个信息并不适用于PostgreSQL 里的数组元素数据类型
character_octet_lengthcardinal_number总是空,因为这个信息并不适用于PostgreSQL 里的数组元素数据类型
character_set_catalogsql_identifier应用于一个PostgreSQL 里没有的特性
character_set_schemasql_identifier应用于一个PostgreSQL 里没有的特性
character_set_namesql_identifier应用于一个PostgreSQL 里没有的特性
collation_catalogsql_identifier应用于一个PostgreSQL 里没有的特性
collation_schemasql_identifier应用于一个PostgreSQL 里没有的特性
collation_namesql_identifier应用于一个PostgreSQL 里没有的特性
numeric_precisioncardinal_number总是空,因为这个信息并不适用于PostgreSQL 里的数组元素数据类型
numeric_precision_radixcardinal_number总是空,因为这个信息并不适用于PostgreSQL 里的数组元素数据类型
numeric_scalecardinal_number总是空,因为这个信息并不适用于PostgreSQL 里的数组元素数据类型
datetime_precisioncardinal_number总是空,因为这个信息并不适用于PostgreSQL 里的数组元素数据类型
interval_typecharacter_data总是空,因为这个信息并不适用于PostgreSQL 里的数组元素数据类型
interval_precisioncharacter_data总是空,因为这个信息并不适用于PostgreSQL 里的数组元素数据类型
domain_defaultcharacter_data尚未实现
udt_catalogsql_identifier元素的数据类型定义所在的数据库名字(总是当前数据库)
udt_schemasql_identifier元素定义所在的模式名字
udt_namesql_identifier元素的数据类型名字
scope_catalogsql_identifier应用于一个PostgreSQL 里没有的特性
scope_schemasql_identifier应用于一个PostgreSQL 里没有的特性
scope_namesql_identifier应用于一个PostgreSQL 里没有的特性
maximum_cardinalitycardinal_number总是为空,因为PostgreSQL 里数组总是有无限的维数
dtd_identifiersql_identifier元素的数据类型描述符的标识符。这个目前没有用处。

<
PrevHomeNext
domainsUpenabled_roles

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文