ES多条件查询写法举例
作者:凭栏听雨客
这篇文章主要给大家介绍了关于ES多条件查询的相关资料,Elasticsearch多条件查询是指在查询数据时,可以同时使用多个条件来筛选数据,文中通过代码介绍的非常详细,需要的朋友可以参考下
场景:想要查询出设备id 为 3 的所有设备上报信息,并且上报信息的开始时间或结束时间只要有一个满足 在 某个时间段里即可。
在 Elasticsearch 中,您可以使用布尔查询来实现同时满足条件1并且满足条件2或条件3中的一个的查询。具体来说,您可以使用“must”子句来指定满足条件1的查询,使用“should”子句来指定满足条件2或条件3中的一个的查询,并将它们组合起来。
以下是一个示例查询:
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”子句必须匹配才能返回结果。
还有另外一种写法:
{ "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”: 指定时区。
总结
到此这篇关于ES多条件查询的文章就介绍到这了,更多相关ES多条件查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!