Elasticsearch通配符搜索多个字段

问题描述 投票:0回答:1

我正在构建过滤器功能,我想要的是通配符过滤器。如果值为“ roj”,则应显示任何包含“ roj”的字段中的所有记录。

如何实现?

这是我的查询,

{
  "query": {
    "bool": {
      "must": [
        {
          "exists": {
            "field": "Project_error"
          }
        },
        {
          "wildcard": {
            "api_name": {
              "wildcard": "*roj*"
            }
          }
        },
        {
          "wildcard": {
            "error_Code": {
              "wildcard": "*roj*"
            }
          }
        }
      ]
    }
  }
}

Java代码

BoolQueryBuilder bqb = new BoolQueryBuilder();
bqb.must(QueryBuilders.existsQuery("Project_error"))

if(!filter.isEmpty()) {
   bqb.filter(QueryBuilders.wildcardQuery(fields[0],"*"+filter+"*"));
   bqb.must(QueryBuilders.wildcardQuery(fields[1],"*"+filter+"*"));
   ...
}

searchSourceBuilder.query(bqb);

仅当两个字段都包含“ roj”时,此脚本才会显示数据,这是不正确的。

java elasticsearch filter wildcard elk
1个回答
0
投票

使用下面的查询,您可以得到结果。

GET <index_name>/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "query_string": {
            "query": "*roj*",
            "fields":["field_1", "field_2"]
          }
        }
      ]
    }
  }
}

如果要在所有字段中应用查询词,请删除上述查询中的字段属性。!!

© www.soinside.com 2019 - 2024. All rights reserved.