pg_amop #目录pg_amop存储关于与访问方法操作符族相关的操作符信息。对于操作符族中的每个成员操作符,此目录中都有一行。一个成员可以是搜索操作符,也可以是排序操作符。一个操作符可以出现在多个族中,但在同一个族中既不能出现在多个搜索位置,也不能出现在多个排序位置(虽然不太可能,但允许一个操作符同时用于搜索和排序)。
Table 50.4. pg_amop 列
|
列类型 描述 |
|---|
|
行标识符 |
|
此项所属的操作符族 |
|
操作符的左手输入数据类型 |
|
操作符的右手输入数据类型 |
|
操作符策略号 |
|
操作符目的, |
|
操作符的OID |
|
此操作符族所属的索引访问方法 |
|
如果是排序操作符,则此项按这个 B-树操作符族排序;如果是搜索操作符,则为零 |
一个“搜索”操作符项表示,该操作符族上的索引可以用来查找满足如下条件的所有行: WHERE indexed_column operator constant。 显然,这样的操作符必须返回boolean,并且它的左输入类型必须匹配索引列的数据类型。
一个“排序”操作符项表示,该操作符族上的索引可以被扫描,以按如下顺序返回行: ORDER BY indexed_column operator constant。 这样的操作符可以返回任何可排序的数据类型,不过它的左输入类型同样必须匹配索引列的数据类型。 ORDER BY 的准确语义由amopsortfamily列指定,它必须引用一个适用于该操作符结果类型的 B-树操作符族。
目前,排序操作符的排序顺序被假定为其所引用操作符族的默认值,即ASC NULLS LAST。将来可能会通过增加额外的列来显式指定排序选项,从而放宽这一假设。
一个项的amopmethod必须和它所包含的操作符族的opfmethod相匹配(这里包括amopmethod是一个为了性能原因而故意对目录结构做的反规范化)。 此外,amoplefttype和amoprighttype也必须匹配被引用的pg_operator项的oprleft和oprright域。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。