場(chǎng)景:想要查詢出設(shè)備id 為 3 的所有設(shè)備上報(bào)信息,并且上報(bào)信息的開始時(shí)間或結(jié)束時(shí)間只要有一個(gè)滿足 在 某個(gè)時(shí)間段里即可。
在 Elasticsearch 中,您可以使用布爾查詢來實(shí)現(xiàn)同時(shí)滿足條件1并且滿足條件2或條件3中的一個(gè)的查詢。具體來說,您可以使用“must”子句來指定滿足條件1的查詢,使用“should”子句來指定滿足條件2或條件3中的一個(gè)的查詢,并將它們組合起來。
以下是一個(gè)示例查詢:
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”參數(shù)被設(shè)置為1,這意味著至少有一個(gè)“should”子句必須匹配才能返回結(jié)果。
還有另外一種寫法:文章來源:http://www.zghlxwxcb.cn/news/detail-491989.html
{
"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"
}
}
}
]
}
}
]
}
}
}
具體解釋如下:文章來源地址http://www.zghlxwxcb.cn/news/detail-491989.html
- “query”: 指定查詢語句。
- “bool”: 使用布爾查詢,實(shí)現(xiàn)多個(gè)查詢條件的組合。
- “must”: 必須匹配的查詢條件,相當(dāng)于邏輯上的"AND"。
- “term”: 匹配一個(gè)精確值的查詢。
- “deviceId”: 待匹配的字段名。
- 3: 待匹配的值。
- “bool”: 使用布爾查詢,實(shí)現(xiàn)多個(gè)查詢條件的組合。
- “should”: 至少匹配一個(gè)查詢條件,相當(dāng)于邏輯上的"OR"。
- “range”: 匹配一個(gè)數(shù)值或日期范圍內(nèi)的查詢。
- “startTime”: 待匹配的字段名。
- “endTime”: 待匹配的字段名。
- “gte”: 大于或等于(greater than or equal to)指定值。
- “l(fā)te”: 小于或等于(less than or equal to)指定值。
- “time_zone”: 指定時(shí)區(qū)。
到了這里,關(guān)于ES多條件查詢的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!