我有一个类似的查询:
我需要提高 user_id_i:(123 OR 222 OR 512 OR 932) 的结果
类似于 => __val_:"if(user_id_i:(123 OR 222 OR 512 OR 932), 100, 0)"
但很明显,我需要一个针对该特定问题返回 true 或 false 的函数。
我有一个类似的查询:
我需要提高 user_id_i:(123 OR 222 OR 512 OR 932) 的结果
类似于 => __val_:"if(user_id_i:(123 OR 222 OR 512 OR 932), 100, 0)"
但很明显,我需要一个针对该特定问题返回 true 或 false 的函数。
我认为您可以boost
为此使用查询参数,但您必须使用 edismax 查询解析器而不是 lucenePlusSort 解析器。(http://wiki.apache.org/solr/ExtendedDisMax#boost_.28Boost_Function.2C_multiplicative.29)
[boost] => product(if(exists(query({!v='user_id_i:(123 OR 222 OR 512 OR 932)'})),100,1))