如何使用 Java 在 Elasticsearch 中进行多过滤器查询?
How to do multiple filter query in Elasticsearch using Java?
我已经在 elasticsearch 之上构建了一个网络应用程序。我想使用 Java 进行多重过滤。
弹性搜索查询:
{
"query": {
"bool": {
"must": [
{"match": {
"T": "TEXT"},
"match": {
"new_content": "TEXT"
}
},
],
"filter": {
"term": {
"collection1": "xyz"
},
"term": {
"collection2": "abc"
}
我想过滤查询,以便它应该过滤具有两个不同值的同一字段 collection
(例如,"xyz" 和 "abc")
现在,我已经为单个过滤器编写了一个 Java 程序。
BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
.must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
.filter(QueryBuilders.termQuery(Collection1, "abc"));
我应该如何为多个值过滤同一字段的查询?
编辑:
实际上在我的网络应用程序中,我提取了集合的值:
String[] Collection=request.getParameterValues("site");
Collection 是我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], "true");
但是当我应用这个过滤器时,我收到了这个错误 The method filter(TermsQueryBuilder) is undefined for the type TermsQueryBuilder
。它说向方法接收器添加强制转换。
您可以使用 terms
查询而不是多个 term
查询:
BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
.must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
.filter(QueryBuilders.termsQuery(Collection, "abc", "xyz"));
^ ^ ^
| | |
use termsQuery with multiple values
更新
我很惊讶你的代码完全可以编译,因为你缺少一些右括号,只需像这样重写你的查询,它应该可以工作:
BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
.must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
.filter(QueryBuilders.termQuery(Collection[0], "true"))
.filter(QueryBuilders.termQuery(Collection[1], "true"));
Term 查询将只为 filed 取一个值,Terms 查询将为 filed
取多个值
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
BoolQueryBuilder QueryBuilders = QueryBuilders.boolQuery();
sourceBuilder.query(QueryBuilders.filter(QueryBuilders.termsQuery("age", "44", "45", "30")));
强文本
searchRequest.source(sourceBuilder);
我已经在 elasticsearch 之上构建了一个网络应用程序。我想使用 Java 进行多重过滤。
弹性搜索查询:
{
"query": {
"bool": {
"must": [
{"match": {
"T": "TEXT"},
"match": {
"new_content": "TEXT"
}
},
],
"filter": {
"term": {
"collection1": "xyz"
},
"term": {
"collection2": "abc"
}
我想过滤查询,以便它应该过滤具有两个不同值的同一字段 collection
(例如,"xyz" 和 "abc")
现在,我已经为单个过滤器编写了一个 Java 程序。
BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
.must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
.filter(QueryBuilders.termQuery(Collection1, "abc"));
我应该如何为多个值过滤同一字段的查询?
编辑:
实际上在我的网络应用程序中,我提取了集合的值:
String[] Collection=request.getParameterValues("site");
Collection 是我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], "true");
但是当我应用这个过滤器时,我收到了这个错误 The method filter(TermsQueryBuilder) is undefined for the type TermsQueryBuilder
。它说向方法接收器添加强制转换。
您可以使用 terms
查询而不是多个 term
查询:
BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
.must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
.filter(QueryBuilders.termsQuery(Collection, "abc", "xyz"));
^ ^ ^
| | |
use termsQuery with multiple values
更新
我很惊讶你的代码完全可以编译,因为你缺少一些右括号,只需像这样重写你的查询,它应该可以工作:
BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
.must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
.filter(QueryBuilders.termQuery(Collection[0], "true"))
.filter(QueryBuilders.termQuery(Collection[1], "true"));
Term 查询将只为 filed 取一个值,Terms 查询将为 filed
取多个值SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
BoolQueryBuilder QueryBuilders = QueryBuilders.boolQuery();
sourceBuilder.query(QueryBuilders.filter(QueryBuilders.termsQuery("age", "44", "45", "30")));
强文本 searchRequest.source(sourceBuilder);