索引使用约束
下面是一个使用索引的例子:
1 2 3 4 5 6 7 8 9 10 11 12 | create table table1 (c_int int,c_bigint bigint,c_varchar varchar,c_text text) with(orientation=row); create text search configuration ts_conf_1(parser=POUND); create text search configuration ts_conf_2(parser=POUND) with(split_flag='%'); set default_text_search_config='ts_conf_1'; create index idx1 on table1 using gin(to_tsvector(c_text)); set default_text_search_config='ts_conf_2'; create index idx2 on tscp_u_m_005_tbl using gin(to_tsvector(c_text)); select c_varchar,to_tsvector(c_varchar) from table1 where to_tsvector(c_text) @@ plainto_tsquery('¥#@……&**') and to_tsvector(c_text) @@ plainto_tsquery('某公司 ') and c_varchar is not null order by 1 desc limit 3; |
该例子的关键点是表table1的同一个列c_text上建立了两个gin索引:idx1和idx2,但这两个索引是在不同default_text_search_config的设置下建立的。该例子和同一张表的同一个列上建立普通索引的不同之处在于:
- gin索引使用了不同的parser(即分隔符不同),那么idx1和idx2的索引数据是不同的;
- 在同一张表的同一个列上建立的多个普通索引的索引数据是相同的;
因此当执行同一个查询时,使用idx1和idx2查询出的结果是不同的。
使用约束
通过上面的例子,索引使用满足如下条件时:
- 在同一个表的同一个列上建立了多个gin索引;
- 这些gin索引使用了不同的parser(即分隔符不同);
- 在查询中使用了该列,且执行计划中使用索引进行扫描;
为了避免使用不同gin索引导致查询结果不同的问题,需要保证在物理表的一列上只有一个gin索引可用。
查看更多:华为GaussDB 200 全文检索表和索引
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。