| PostgreSQL 8.0.0 中文文件(轉譯自 PostgreSQL 中國 製作的簡體中文版本) | ||||
|---|---|---|---|---|
| Prev | Fast Backward | Chapter 30. 訊息模式 | Fast Forward | Next |
視圖 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 30-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 | 元素的資料類型描述符的標識符。這個目前沒有用處。 |