solr lucene仅在查询匹配文本时应用bf

solr lucene仅在查询匹配文本时应用bf,solr,lucene,edismax,Solr,Lucene,Edismax,当查询“来自john的电子邮件”与文本“来自john的电子邮件的其他文本”匹配时,查询中的每个单词都以这种精确格式存在于文本字段中: 然后,也只有这样,我才需要应用bf函数 是否可以通过Solr实现此规则/功能 谢谢, Peter我想是的,您只需要在solrconfig.xml中创建一个新的请求处理程序来应用该函数: <requestHandler name="/match" class="solr.SearchHandler"> <lst name="defaults">

当查询“来自john的电子邮件”与文本“来自john的电子邮件的其他文本”匹配时,查询中的每个单词都以这种精确格式存在于文本字段中:

然后,也只有这样,我才需要应用bf函数

是否可以通过Solr实现此规则/功能

谢谢,
Peter

我想是的,您只需要在solrconfig.xml中创建一个新的请求处理程序来应用该函数:

<requestHandler name="/match" class="solr.SearchHandler">
<lst name="defaults">
    <str name="echoParams">all</str>
    <str name="defType">edismax</str>
    <str name="rows">5</str>
    <str name="fl">*,score</str>
    <str name="bf">product(log(sum(popularity,1)),100)^20</str>
    <str name="boost">product(map(query($type1query),0,0,1,$type1boost),map(query($type2query),0,0,1,$type2boost),map(query($type3query),0,0,1,$type3boost),map(query($type4query),0,0,1,$type4boost),$typeboost)</str>
    <double name="typeboost">1.0</double>

    <str name="type1query">type:"type1"</str>
    <double name="type1boost">0.9</double>
    <str name="type2query">type:"type2"</str>
    <double name="type2boost">0.5</double>
    <str name="type3query">type:"type3"</str>
    <double name="type3boost">0.3</double>
    <str name="type4query">type:"type4"</str>
    <double name="type4boost">0.1</double>
    <str name="debugQuery">false</str>
    <str name="omitHeader">true</str> 
    <str name="wt">json</str> 
    <str name="indent">true</str> 
</lst>

我不知道。您使用Solr的地方有哪一个应用层?e、 g.当有一个Java客户端(使用Solrj)时,如果查询中包含一些文本,添加bf将非常容易…@cheffe我正在从cms系统调用Solr,该系统名为CQ5。你能提供一个简单的例子来说明如何使用Solrj吗?为什么不使用短语增强呢?这与你需要做的非常接近。唯一的区别是,在短语中,单词必须以相同的顺序出现。您只需要使用字段名称和每个字段的权重来指定pf参数。
http://localhost:8983/solr/collection1/match?q=*email from john