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": 指定时区。
相关推荐
lang201509288 分钟前
Spring Boot日志配置完全指南
java·spring boot·单元测试
在坚持一下我可没意见12 分钟前
HTTP 协议基本格式与 Fiddler 抓包工具实战指南
java·开发语言·网络协议·tcp/ip·http·java-ee·fiddler
GOATLong27 分钟前
git使用
大数据·c语言·c++·git·elasticsearch
蓝-萧34 分钟前
Plugin ‘mysql_native_password‘ is not loaded`
java·后端
故事不长丨39 分钟前
【Java SpringBoot+Vue 实现视频文件上传与存储】
java·javascript·spring boot·vscode·后端·vue·intellij-idea
不修×蝙蝠1 小时前
Java 日志演进:一文读懂主流框架
java·log4j·logback·log4j2·日志·slf4j
robin_suli1 小时前
数据库之多版本控制MVCC
java·数据库
鬼火儿2 小时前
Golang笔记——Interface类型
java·后端
蓝-萧2 小时前
Redis——Windows安装
java·后端
祈祷苍天赐我java之术2 小时前
如何在Java中整合Redis?
java·开发语言·redis