gpt4 book ai didi

java - Solr 单独过滤出分面结果

转载 作者:塔克拉玛干 更新时间:2023-11-02 19:29:30 26 4
gpt4 key购买 nike

我正在根据预定义的标准列表过滤掉 solr 返回的方面。

例如,我正在查询不同类型的文档。返回的切面如下:

<lst name="facet_counts">
<lst name="facet_queries"/>
<lst name="facet_fields">
<lst name="applicationName">
<int name="microsoft">2304</int>
<int name="word">2277</int>
<int name="0">1550</int>
<int name="office">598</int>
<int name="8">471</int>
<int name="9">446</int>
<int name="90">445</int>
<int name="10">435</int>
<int name="100">426</int>
<int name="9.0">418</int>
<int name="10.0">411</int>
<int name="8.0">375</int>
<int name="80">375</int>
<int name="2">328</int>
<int name="5">308</int>
<int name="acrobat">272</int>

假设我不想将 microsoft 作为此 facet_field 的结果显示。当前的查询如下所示。我已经尝试使用标签和排除过滤器,但我运气不好......

q=*%3A*&wt=xml&indent=true&facet=true&facet.field=applicationName

编辑我目前的解决方案是添加自定义搜索处理程序并执行过滤后查询执行。我希望通过查询机制获得一个解决方案,这种方式涉及较少的处理。

最佳答案

您是否尝试过“facet.query”参数?如果我正确理解了您的问题,如果您在请求中添加 facet.query=-applicationName:microsoft,Solr 将完全按照您的要求执行。所以,它应该是这样的:

q=%3A&facet=true&facet.field=applicationName&facet.query=-applicationName:microsoft


编辑:上面的提示是错误的。它只会返回字段“applicationName”中没有“microsoft”的文档数。

您应该对“q”参数进行相同的查询。就这样:

q=-applicationName:microsoft&facet=true&facet.field=applicationName

关于java - Solr 单独过滤出分面结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16306663/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com