ES(Elasticsearch)是一个开源的分布式搜索和分析引擎,具有强大的全文搜索功能。在ES中,可以使用多条件查询来过滤搜索结果。

多条件查询可以通过使用bool查询或者过滤器来实现。下面是两种常见的多条件查询的示例:

  1. 使用bool查询:
GET /index/_search
{
  "query": {
    "bool": {
      "must": [
        { "term": { "field1": "value1" } },
        { "term": { "field2": "value2" } }
      ],
      "must_not": [
        { "term": { "field3": "value3" } }
      ],
      "should": [
        { "term": { "field4": "value4" } }
      ]
    }
  }
}

上述查询表示要求满足field1等于value1并且field2等于value2的条件,同时不满足field3等于value3的条件,还可以选择满足field4等于value4的条件。

  1. 使用过滤器:
GET /index/_search
{
  "query": {
    "bool": {
      "filter": [
        { "term": { "field1": "value1" } },
        { "term": { "field2": "value2" } }
      ]
    }
  }
}

上述查询表示只返回满足field1等于value1并且field2等于value2的结果,不计算相关性得分。

以上示例仅为ES多条件查询的简单示例,实际应用中可以根据具体需求选择合适的查询方式和条件组合

es多条件查询

原文地址: http://www.cveoy.top/t/topic/ieuN 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录