ES多条件查询

场景:想要查询出设备id 为 3 的所有设备上报信息,并且上报信息的开始时间或结束时间只要有一个满足 在 某个时间段里即可。

在 Elasticsearch 中,您可以使用布尔查询来实现同时满足条件1并且满足条件2或条件3中的一个的查询。具体来说,您可以使用"must"子句来指定满足条件1的查询,使用"should"子句来指定满足条件2或条件3中的一个的查询,并将它们组合起来。

以下是一个示例查询:

json 复制代码
GET /my_index/_search
{
  "query": {
    "bool": {
      "must": [
        { "term": { "deviceId": 3 } }
      ],
      "should": [
              {
                "range": {
                  "startTime": {
                    "gte": "2023-10-11T23:12:02+08:00",
                    "lte": "2023-10-11T23:12:02+08:00",
                    "time_zone": "+08:00"
                  }
                }
              },
              {
                "range": {
                  "endTime": {
                    "gte": "2023-10-11T23:12:02+08:00",
                    "lte": "2023-10-11T23:12:02+08:00",
                    "time_zone": "+08:00"
                  }
                }
              }
            ],
      "minimum_should_match": 1
    }
  }
}

"minimum_should_match"参数被设置为1,这意味着至少有一个"should"子句必须匹配才能返回结果。

还有另外一种写法:

json 复制代码
{
  "query": {
    "bool": {
      "must": [
        {
          "term": {
            "deviceId": 3
          }
        },
        {
          "bool": {
            "should": [
              {
                "range": {
                  "startTime": {
                    "gte": "2023-10-11T23:12:02+08:00",
                    "lte": "2023-10-11T23:12:02+08:00",
                    "time_zone": "+08:00"
                  }
                }
              },
              {
                "range": {
                  "endTime": {
                    "gte": "2023-10-11T23:12:02+08:00",
                    "lte": "2023-10-11T23:12:02+08:00",
                    "time_zone": "+08:00"
                  }
                }
              }
            ]
          }
        }
      ]
    }
  }
}

具体解释如下:

  • "query": 指定查询语句。
  • "bool": 使用布尔查询,实现多个查询条件的组合。
  • "must": 必须匹配的查询条件,相当于逻辑上的"AND"。
  • "term": 匹配一个精确值的查询。
  • "deviceId": 待匹配的字段名。
  • 3: 待匹配的值。
  • "bool": 使用布尔查询,实现多个查询条件的组合。
  • "should": 至少匹配一个查询条件,相当于逻辑上的"OR"。
  • "range": 匹配一个数值或日期范围内的查询。
  • "startTime": 待匹配的字段名。
  • "endTime": 待匹配的字段名。
  • "gte": 大于或等于(greater than or equal to)指定值。
  • "lte": 小于或等于(less than or equal to)指定值。
  • "time_zone": 指定时区。
相关推荐
Hx_Ma165 小时前
SpringMVC框架提供的转发和重定向
java·开发语言·servlet
期待のcode5 小时前
原子操作类LongAdder
java·开发语言
舟舟亢亢6 小时前
Java集合笔记总结
java·笔记
小酒窝.6 小时前
【多线程】多线程打印ABC
java
乡野码圣6 小时前
【RK3588 Android12】RCU机制
java·jvm·数据库
JAVA+C语言6 小时前
如何优化 Java 多主机通信的性能?
java·开发语言·php
编程彩机8 小时前
互联网大厂Java面试:从分布式架构到大数据场景解析
java·大数据·微服务·spark·kafka·分布式事务·分布式架构
小酒窝.8 小时前
【多线程】多线程打印1~100
java·多线程
君爱学习8 小时前
基于SpringBoot的选课调查系统
java
APIshop8 小时前
Java 实战:调用 item_search_tmall 按关键词搜索天猫商品
java·开发语言·数据库