我已经在Elasticsearch之上构建了一个Web应用程序。我想使用Java进行多重过滤。
Elasticsearch查询:
{
"query": {
"bool": {
"must": [
{"match": {
"T": "TEXT"},
"match": {
"new_content": "TEXT"
}
},
],
"filter": {
"term": {
"collection1": "xyz"
},
"term": {
"collection2": "abc"
}
Run Code Online (Sandbox Code Playgroud)
我想过滤查询,以便它应该在collection具有两个不同值(例如“ xyz”和“ abc”)的同一字段上进行过滤
现在,我已经为单个过滤器编写了Java程序。
BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
.must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
.filter(QueryBuilders.termQuery(Collection1, "abc"));
Run Code Online (Sandbox Code Playgroud)
如何在同一字段上为多个值过滤查询?
编辑:
实际上,在我的Web应用程序中,我将集合的值提取为:
String[] Collection=request.getParameterValues("site");
Run Code Online (Sandbox Code Playgroud)
收藏是我的Elasticsearch文档中的字段。假设Collection[0]是germany_collection(value:true),Collection[1]是usa_collection(value:true)。我想写一个查询来过滤我的文档,以便在germany_collection:true和usa_collection:true时得到结果。
这是我的原始程序:
public StringBuffer getJson(String query, String start, String [] Collection{
Client client = TransportClient.builder().build()
.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("127.0.0.1"), 9300));
BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
.must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
.filter(QueryBuilders.termQuery(Collection[0], "true").filter(QueryBuilders.termQuery(Collection[1], …Run Code Online (Sandbox Code Playgroud)