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": 指定时区。
相关推荐
飞翔中文网13 分钟前
Java学习笔记之抽象类
java·笔记·学习
海盗123419 分钟前
C#中PDF操作-QuestPDF页面设置与布局
java·pdf·c#
day day day ...30 分钟前
MyBatis / MyBatis-Plus 动态 SQL 中 OGNL 表达式的常见陷阱与源码分析
java·开发语言·mybatis
Kiling_070437 分钟前
Java IO流:字节流实战与性能优化
java·开发语言·php
January12071 小时前
IDEA 快捷键
java·ide·intellij-idea
周杰伦fans1 小时前
C# 异常继承深度解析:从设计原则到 sealed 关键字的奥秘
java·jvm·c#
搬石头的马农1 小时前
从零配置Claude自动修Bug:6步打造全自动开发流程
java·人工智能·python·bug·ai编程
小马爱打代码1 小时前
Redis Key 过期后会立刻删除吗?过期删除与内存淘汰策略详解
java·redis·缓存
鱼鳞_1 小时前
苍穹外卖-Day10(Spring task)
java·后端·spring
雨落在了我的手上1 小时前
初始java(十七):常⽤⼯具类介绍
java·开发语言