对于自动完成功能,我使用了术语组件以及可以正常工作的木瓦过滤器。现在我也要映射同义词。
之前我在查询时使用了分面和同义词正常工作。但是现在当我在索引时添加它时,我没有得到正确的结果。
schema.xml中的配置如下:
<fieldType name="text_synonyms_category" class="solr.TextField" positionIncrementGap="100">
<analyzer type="index">
<tokenizer class="solr.StandardTokenizerFactory"/>
<filter class="solr.ShingleFilterFactory" />
<filter class="solr.SynonymFilterFactory" synonyms="synonyms_category.txt" ignoreCase="true" expand="true"/>
</analyzer>
<analyzer type="query">
<tokenizer class="solr.KeywordTokenizerFactory"/>
<filter class="solr.LowerCaseFilterFactory"/>
<filter class="solr.WordDelimiterFilterFactory" generateWordParts="0" generateNumberParts="0" splitOnNumerics="0" catenateWords="0" catenateNumbers="0" catenateAll="1" stemEnglishPossessive="0" splitOnCaseChange="0"/>
<filter class="solr.SynonymFilterFactory" synonyms="synonyms_category.txt" ignoreCase="true" expand="true"/> <!-- tokenizerFactory="solr.KeywordTokenizerFactory"/>-->
<filter class="solr.StopFilterFactory" ignoreCase="true" words="stopwords.txt" />
</analyzer>
</fieldType>
例如,在synonyms_category.txt中,我有以下条目:
cat synonyms_category.txt
Iphone=>mobilephones,cases&covers
apple=>mobilephones,tablets,smartwatches
但是在查询方面,在搜索iphone时,它还没有解决到手机:
http://<solr-server>/solr/<core>/terms?terms.fl=category&terms.regex=iphone.*
响应:
<response>
<lst name="responseHeader">
<int name="status">0</int>
<int name="QTime">4</int>
</lst>
<lst name="terms">
<lst name="category"/>
</lst>
</response>
似乎术语组件不考虑同义词。不确定我的期望是否正确但是因为它适用于查询类型我尝试用于术语。