我在pg_trgm
模块中使用GIN索引来索引varchar
字段。因此,要定义索引,我必须编写如下内容:
CREATE INDEX gin_field_idx ON table_name USING gin (field gin_trgm_ops);
如果我排除操作符类(git_trgm_ops
)并编写:
CREATE INDEX gin_field_idx ON table_name USING gin (field);
PostgreSQL将引发一个错误:
错误:对于访问方法"gin“提示,数据类型字符变量没有默认操作符类:必须为索引指定操作符类,或者为数据类型定义默认运算符类。
如何从模块中定义默认运算符方法?
这不起作用。它描述了如何从扩展运算符和函数定义新的运算符类。但是我必须从模块中定义默认的运算符类。
如有任何帮助,将不胜感激:)。
发布于 2016-08-02 02:46:09
您可以更新pg_opclass表并设置默认值。
update pg_opclass set opcdefault = true where opcname='gin_trgm_ops'
默认情况下,pg_trgm不会这样做,因为您可能需要/希望使用不同的GIN默认值。
select * from pg_opclass where opcname = 'gin_trgm_ops';
无法创建索引:
create index ON table USING gin (field); -- it will use the new default
https://dba.stackexchange.com/questions/145586
复制相似问题