32.16. 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.array_type_identifier))
WHERE c.table_schema = '...' AND c.table_name = '...'
ORDER BY c.ordinal_position;

這個視圖只包含當前用戶有權限訪問的對象,也就是他是所有者或者有些 權限。

Table 32-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 元素的數據類型描述符的標識符。這個目前沒有用處。