【问题标题】:SOLR search is not showing valid resultSOLR 搜索未显示有效结果
【发布时间】:2012-05-28 06:13:28
【问题描述】:

我正在使用 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"/>

【问题讨论】:

  • 你能把你schema.xml的相关部分贴出来吗?
  • hi zi42,请查看我的“我的 Schema.xml 文件中的某些部分”。部分。我已经更新了上述问题。谢谢
  • 请检查我的回答。如果您在索引部分需要帮助,请告诉我您使用的是什么语言/适配器,我会为您指出一些代码,这些代码可以满足您对多值字段的要求。

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


【解决方案1】:

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

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

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

【讨论】:

  • @zia42,我的问题有点不同。在某些情况下,查询 SubscriptionIds: (,4855,) && ABCId:(ASEJ54855) 但对另一个 ABCId: TYEEW46222 的类似查询没有得到我的记录。例如: SubscriptionIds: (,4855,) && ABCId:(TYEEW46222) 没有得到任何结果。但是,如果我们只输入 ABCId: (TYEEW46222),我们可以在结果中看到 SubscriptionIds 字段中的值是 ,4855。
  • 我明白了。但是,为什么要通过将 ID 存储为逗号分隔列表的复杂路径而不是正确的存储方式呢?
猜你喜欢
  • 2011-05-10
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-04-07
  • 2021-02-23
  • 2021-09-24
相关资源
最近更新 更多