?
This document uses PHP Chinese website manual Release
視圖element_types包含數(shù)組元素的數(shù)據(jù)類型的描述符。在一個(gè)表字段,域, 函數(shù)參數(shù),或者函數(shù)返回值定義為一個(gè)數(shù)組類型的時(shí)候, 對應(yīng)的信息模式視圖在字段data_type里只包含 ARRAY。 要獲取數(shù)組元素類型的信息,你可以將對應(yīng)的視圖和這個(gè)視圖連接。 比如,要用數(shù)據(jù)類型和數(shù)組元素類型顯示表的字段,(如果可能),你可以用
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.dtd_identifier)) WHERE c.table_schema = '...' AND c.table_name = '...' ORDER BY c.ordinal_position;
這個(gè)視圖只包含當(dāng)前用戶具有權(quán)限訪問的對象,也就是他是所有者或者有些權(quán)限。
Table 34-17. element_types 字段
名字 | 數(shù)據(jù)類型 | 描述 |
---|---|---|
object_catalog | sql_identifier | 使用了被描述的數(shù)組的對象所在的數(shù)據(jù)庫名(總是當(dāng)前數(shù)據(jù)庫) |
object_schema | sql_identifier | 使用了被描述的數(shù)組的對象所在的模式名 |
object_name | sql_identifier | 使用了被描述的數(shù)組的對象的名字 |
object_type | character_data | 使用了被描述的數(shù)組的對象的類型:TABLE(數(shù)組被該表的一個(gè)字段使用), DOMAIN(數(shù)組被這個(gè)域使用), ROUTINE(數(shù)組被該函數(shù)的一個(gè)參數(shù)或者返回?cái)?shù)據(jù)類型使用)之一。 |
dtd_identifier | sql_identifier | 被描述的數(shù)組的數(shù)據(jù)類型描述符標(biāo)識(shí)符。 |
data_type | character_data | 如果這是一個(gè)內(nèi)置的類型,數(shù)據(jù)元素的數(shù)據(jù)類型,否則就是USER-DEFINED(這種情況下,類型在udt_name和相關(guān)的字段中標(biāo)出)。 |
character_maximum_length | cardinal_number | 總是空,因?yàn)檫@個(gè)信息并不適用于PostgreSQL里的數(shù)組元素?cái)?shù)據(jù)類型。 |
character_octet_length | cardinal_number | 總是空,因?yàn)檫@個(gè)信息并不適用于PostgreSQL里的數(shù)組元素?cái)?shù)據(jù)類型 |
character_set_catalog | sql_identifier | 用于PostgreSQL里一個(gè)不可用的特性 |
character_set_schema | sql_identifier | 用于PostgreSQL里一個(gè)不可用的特性 |
character_set_name | sql_identifier | 用于PostgreSQL里一個(gè)不可用的特性 |
collation_catalog | sql_identifier | 用于PostgreSQL里一個(gè)不可用的特性 |
collation_schema | sql_identifier | 用于PostgreSQL里一個(gè)不可用的特性 |
collation_name | sql_identifier | 用于PostgreSQL里一個(gè)不可用的特性 |
numeric_precision | cardinal_number | 總是空,因?yàn)檫@個(gè)信息并不適用于PostgreSQL里的數(shù)組元素?cái)?shù)據(jù)類型 |
numeric_precision_radix | cardinal_number | 總是空,因?yàn)檫@個(gè)信息并不適用于PostgreSQL里的數(shù)組元素?cái)?shù)據(jù)類型 |
numeric_scale | cardinal_number | 總是空,因?yàn)檫@個(gè)信息并不適用于PostgreSQL里的數(shù)組元素?cái)?shù)據(jù)類型 |
datetime_precision | cardinal_number | 總是空,因?yàn)檫@個(gè)信息并不適用于PostgreSQL里的數(shù)組元素?cái)?shù)據(jù)類型 |
interval_type | character_data | 總是空,因?yàn)檫@個(gè)信息并不適用于PostgreSQL里的數(shù)組元素?cái)?shù)據(jù)類型 |
interval_precision | character_data | 總是空,因?yàn)檫@個(gè)信息并不適用于PostgreSQL里的數(shù)組元素?cái)?shù)據(jù)類型 |
domain_default | character_data | 未實(shí)現(xiàn) |
udt_catalog | sql_identifier | 元素的數(shù)據(jù)類型定義所在的數(shù)據(jù)庫名(總是當(dāng)前數(shù)據(jù)庫) |
udt_schema | sql_identifier | 元素定義所在的模式名 |
udt_name | sql_identifier | 元素的數(shù)據(jù)類型名 |
scope_catalog | sql_identifier | 用于PostgreSQL里一個(gè)不可用的特性 |
scope_schema | sql_identifier | 用于PostgreSQL里一個(gè)不可用的特性 |
scope_name | sql_identifier | 用于PostgreSQL里一個(gè)不可用的特性 |
maximum_cardinality | cardinal_number | 總是空,因?yàn)檫@個(gè)信息并不適用于PostgreSQL里的數(shù)組元素?cái)?shù)據(jù)類型 |