赞
踩
场景:想要查询出设备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"
}
}
}
]
}
}
]
}
}
}
具体解释如下:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。