SOLR搜索未显示有效结果

时间:2012-05-28 06:13:29

标签: asp.net-mvc-3 solr solrnet

我正在使用SOLR作为我的应用程序的搜索引擎。但现在它没有显示出正确的结果。

在我的架构文件中有列SubscriptionIds,它使用分隔符保存多个值。它们存储为,, 4588 ,, 4585,,6966,,4855,

同样,还有另一列ABCId,其中包含单个值SKJJ54855

当我触发查询时:

ABCId:(SKJJ54855)

它显示我的记录,其Subscriptions的值为,, 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"/>

1 个答案:

答案 0 :(得分:2)

我的建议是使字段SubscriptionIds具有多值,并分别存储许多ID。这将比逗号分隔列表更能代表实际数据。将其更改为:

<field name="SubscriptionIds" type="int" indexed="true" stored="true" multiValued="true" />

并更改索引代码以将多个ID添加到SubscriptionIds字段。