当查询"来自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>
并构建一个只匹配以下单词的查询:
http://localhost:8983/solr/collection1/match?q=*email from john