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 ,这是一次出于性能原因的故意反规范化目录结构)。另外, amoplefttypeamoprighttype 必须分别与被引用 pg_operator 条目的 oprleftoprright 字段相匹配。