在一个字段中为多个值构建Lucene查询
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在一个字段中为多个值构建Lucene查询相关的知识,希望对你有一定的参考价值。
我有一个字段和多个值,我正在尝试构建一个看起来像这样的简单查询
field:(value1 value2 value3)
我有一个包含字段和值的地图,我正在做这样的事情
fieldsMap
"field1" -> "[data1]"
"field2" -> "[value1,value2,value3]"
用于构建lucene查询的代码:
fieldsMap
.entrySet()
.forEach(field -> {
try {
QueryParser queryParser = new ComplexPhraseQueryParser(field.getKey(), new StandardAnalyzer());
booleanQueryBuilder.add(queryParser.parse(QueryParser.escape(field.getValue())), BooleanClause.Occur.MUST);
} catch (ParseException e) {
e.printStackTrace();
}
});
生成的输出:
+field1:data1 +(field2:val1 field2:val2 field2:val3)
但是我怎么能产生这样的东西呢
+field1:data1 +field2:(value1 value2 value3)
答案
你已经做了。 +field1:data1 +(field2:val1 field2:val2 field2:val3)
相当于+field1:data1 +field2:(val1 val2 val3)
以上是关于在一个字段中为多个值构建Lucene查询的主要内容,如果未能解决你的问题,请参考以下文章