Asp.net mvc 3 SOLR搜索未显示有效结果

Asp.net mvc 3 SOLR搜索未显示有效结果,asp.net-mvc-3,solr,solrnet,Asp.net Mvc 3,Solr,Solrnet,我使用SOLR作为我的应用程序的搜索引擎。但现在它没有显示出适当的结果 在我的模式文件中有一个列subscriptionId,它用分隔符保存多个值。它们存储为、、4588、、4585、、6966、、4855、 类似地,还有另一列ABCId,其中保存一个值SKJJ54855 当我发出查询时: ABCId:(SKJJ54855) SubscriptionIds: (,4855,) && ABCId:(SKJJ54855) 它向我显示的记录的下标值为、、4588、、4585、、69

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

在我的模式文件中有一个列
subscriptionId
,它用分隔符保存多个值。它们存储为、、4588、、4585、、6966、、4855、

类似地,还有另一列
ABCId
,其中保存一个值SKJJ54855

当我发出查询时:

ABCId:(SKJJ54855)
SubscriptionIds: (,4855,) && ABCId:(SKJJ54855)
它向我显示的记录的下标值为、、4588、、4585、、6966、、4855、

但当我提出疑问时:

ABCId:(SKJJ54855)
SubscriptionIds: (,4855,) && ABCId:(SKJJ54855)
这并没有给我结果

还有一个例子,当我启动一个查询时:subscriptionId:(,6966,)&&ABCId:(SKJJ54855)

它让我得到结果。。。供您参考(,6966,)位于SubscriptionID列表的倒数第二位

为什么它的行为如此怪异

我的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"/>

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

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


并更改索引代码以向SubscriptionID字段添加多个ID。

您可以发布
schema.xml
的相关部分吗?您好,zi42,请查看我的“我的schema.xml文件的某些部分”部分。我已更新了上述问题。谢谢,请核对我的答案。如果您需要有关索引部分的帮助,请告诉我您使用的语言/适配器,我将为您指出一些代码,这些代码可以满足您对多值字段的要求。@zia42,我的问题有点不同。在某些情况下,查询subscriptionId:(,4855,)&&ABCId:(ASEJ54855),但对另一个ABCId:TYEEW46222的类似查询不会获取me记录。例:subscriptionId:(,4855,)&&ABCId:(TYEEW46222)没有得到任何结果。但若我们只是键入ABCId:(TYEEW46222)我们可以在结果中看到subscriptionId字段中的值是4855,我理解。但是,为什么要经历将ID存储为逗号分隔列表的复杂过程,而不是以正确的方式存储呢?