Postgresql 中文操作指南
53.4. pg_amop #
目录_pg_amop_存储与访问方法运算符系列相关的运算符的信息。对于每个属于运算符系列的运算符,都有一个行。系列成员可以是_search_运算符或者_ordering_运算符。一个运算符可以出现在多个系列中,但不能在系列中的多个搜索位置或多个排序位置内出现。(运算符既用于搜索,又用于排序目的,虽然不太可能,但这是允许的。)
Table 53.4. pg_amop Columns
Column Type Description |
oid oid Row identifier |
amopfamily oid (引用 pg_opfamily . oid )此条目针对的操作符系列 |
amoplefttype oid (引用 pg_type . oid )操作符的左手输入数据类型 |
amoprighttype oid (引用 pg_type . oid )操作符的右手输入数据类型 |
amopstrategy int2 Operator strategy number |
amoppurpose char 操作符用途,用于 s 搜索或 o 排序 |
amopopr oid (引用 pg_operator . oid )操作符的 OID |
amopmethod oid (引用 pg_am . oid )索引访问方法操作符系列针对的操作 |
amopsortfamily oid (引用 pg_opfamily . oid )如果为排序操作符,此条目将根据 B 树操作符系列进行排序;如果为搜索操作符,则为零。 |
“搜索”算子项指示可以针对该算子族的索引执行搜索以查找满足 WHERE indexed_column operator constant 的所有行。显然,此类算子必须返回 boolean,而且其左输入类型必须与索引的列数据类型相匹配。
“排序”算子项指示可以扫描该算子族的索引以按照 ORDER BY indexed_column operator constant 表示的顺序返回行。此类算子可返回任何可排序的数据类型,但同样,其左输入类型必须与索引的列数据类型相匹配。ORDER BY 的确切语义由 amopsortfamily 列指定,该列必须为算子结果类型的 B 树算子族引用。
Note
目前,假定排序运算符的排序顺序是对引用的运算符系列的默认设置,即 ASC NULLS LAST。将来可以通过添加附加列来明确指定排序选项,从而使得这一点得到放松。
条目的 amopmethod 必须与其包含的操作符系列的 opfmethod 相匹配(包括 amopmethod ,这是一次出于性能原因的故意反规范化目录结构)。另外, amoplefttype 和 amoprighttype 必须分别与被引用 pg_operator 条目的 oprleft 和 oprright 字段相匹配。