我使用 SOLR 作为我的应用程序的搜索引擎。但现在它没有显示出正确的结果。
在我的模式文件中,有一列SubscriptionIds
包含多个带有分隔符的值。它们存储为,,4588,,4585,,6966,,4855,
同样,还有另一列ABCId
包含单个值 SKJJ54855
当我发起查询时:
ABCId:(SKJJ54855)
它向我显示了订阅值为 ,,4588,,4585,,6966,,4855 的记录,
但是当我发起查询时:
SubscriptionIds: (,4855,) && ABCId:(SKJJ54855)
它没有给我结果!!!!
还有一种情况,当我发起查询时: SubscriptionIds: (,6966,) && ABCId:(SKJJ54855)
它让我得到结果...供您参考 (,6966,) 在 SubscriptionIds 列表中排在倒数第二位。
为什么它的行为如此奇怪.!!!
我的 Schema.xml 文件中的某些部分。
<fieldType name="textgen" class="solr.TextField" positionIncrementGap="100">
<analyzer type="index">
<tokenizer class="solr.WhitespaceTokenizerFactory"/>
<filter class="solr.StopFilterFactory" ignoreCase="true" words="stopwords.txt" enablePositionIncrements="true" />
<filter class="solr.WordDelimiterFilterFactory" generateWordParts="1" generateNumberParts="1" catenateWords="1" catenateNumbers="1" catenateAll="0" splitOnCaseChange="0"/>
<filter class="solr.LowerCaseFilterFactory"/>
</analyzer>
<analyzer type="query">
<tokenizer class="solr.WhitespaceTokenizerFactory"/>
<filter class="solr.SynonymFilterFactory" synonyms="synonyms.txt" ignoreCase="true" expand="true"/>
<filter class="solr.StopFilterFactory"
ignoreCase="true"
words="stopwords.txt"
enablePositionIncrements="true"
/>
<filter class="solr.WordDelimiterFilterFactory" generateWordParts="1" generateNumberParts="1" catenateWords="0" catenateNumbers="0" catenateAll="0" splitOnCaseChange="0"/>
<filter class="solr.LowerCaseFilterFactory"/>
</analyzer>
</fieldType>
<field name="SubscriptionIds" type="textgen" indexed="true" stored="true" />
<fieldType name="string" class="solr.StrField" sortMissingLast="true" omitNorms="true"/>
<field name="ABCId" type="string" indexed="true" stored="true"/>