CREATE OPERATOR CLASS(7) | SQL Commands | CREATE OPERATOR CLASS(7) |
CREATE OPERATOR CLASS - 定義一個新的運算子類
CREATE OPERATOR CLASS name [ DEFAULT ] FOR TYPE data_type USING index_method AS { OPERATOR strategy_number operator_name [ ( op_type, op_type ) ] [ RECHECK ] | FUNCTION support_number funcname ( argument_type [, ...] ) | STORAGE storage_type } [, ... ]
CREATE OPERATOR CLASS 定義一個新的運算子表。 一個運算子表定義一種特定的資料型別可以如何與一種索引一起使用。 運算子表宣告特定的運算子可以為這種資料型別以及這種索引方法填充特定角色或者"策略"。 運算子表還宣告索引方法在為一個索引欄位選定該運算子表的時候要使用的支援過程。 所有運算子表使用的函式和運算子都必須在建立運算子表之前定義。
如果給出了模式名字,那麼運算子表就在指定的模式中建立。
否則就在當前模式中建立(在搜尋路徑前面的那個;參閱
CURRENT_SCHEMA())。
在同一個模式中的兩個運算子表可以有同樣的名字,但它們必須用於不同的索引方法。
定義運算子表的使用者成為其所有者。目前,創造者必須是超級使用者。
(作這樣的限制是因為一個有問題的運算子表定義會讓伺服器困惑,甚至崩潰。)
CREATE OPERATOR CLASS 目前並不檢查這個類定義是否包含所有索引方法需要運算子以及函式。 定義一個合法的運算子表是使用者的責任。
參考 ``Interfacing Extensions to Indexes''
獲取更多資訊。
OPERATOR,FUNCTION,和 STORAGE 子句可以按照任意順序出現。
下面的例子命令為資料型別 _int4(int4 的陣列)定義了一個 GiST 索引運算子表。 參閱 contrib/intarray/ 獲取完整的例子。
CREATE OPERATOR CLASS gist__int_ops DEFAULT FOR TYPE _int4 USING gist AS OPERATOR 3 &&, OPERATOR 6 = RECHECK, OPERATOR 7 @, OPERATOR 8 ~, OPERATOR 20 @@ (_int4, query_int), FUNCTION 1 g_int_consistent (internal, _int4, int4), FUNCTION 2 g_int_union (bytea, internal), FUNCTION 3 g_int_compress (internal), FUNCTION 4 g_int_decompress (internal), FUNCTION 5 g_int_penalty (internal, internal, internal), FUNCTION 6 g_int_picksplit (internal, internal), FUNCTION 7 g_int_same (_int4, _int4, internal);
CREATE OPERATOR CLASS 是一個 PostgreSQL 擴充套件。 在 SQL 標準中沒有 CREATE OPERATOR CLASS。
ALTER OPERATOR CLASS [alter_operator_class(7)], DROP OPERATOR CLASS [drop_operator_class(l)]
Postgresql 中文網站 何偉平 <laser@pgsqldb.org>
本頁面中文版由中文
man 手冊頁計劃提供。
中文 man
手冊頁計劃:https://github.com/man-pages-zh/manpages-zh
2003-11-02 | SQL - Language Statements |