受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

50.4. pg_amop #

目录pg_amop存储关于与访问方法操作符族相关的操作符信息。对于操作符族中的每个成员操作符,此目录中都有一行。一个成员可以是搜索操作符,也可以是排序操作符。一个操作符可以出现在多个族中,但在同一个族中既不能出现在多个搜索位置,也不能出现在多个排序位置(虽然不太可能,但允许一个操作符同时用于搜索和排序)。

Table 50.4. pg_amop

列类型

描述

oid oid

行标识符

amopfamily oid (引用 pg_opfamily.oid

此项所属的操作符族

amoplefttype oid (引用 pg_type.oid

操作符的左手输入数据类型

amoprighttype oid (引用 pg_type.oid

操作符的右手输入数据类型

amopstrategy int2

操作符策略号

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域。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。