ES多條件查詢寫法舉例
更新時間:2023年11月14日 11:54:55 作者:憑欄聽雨客
這篇文章主要給大家介紹了關于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”: 指定時區(qū)。
總結
到此這篇關于ES多條件查詢的文章就介紹到這了,更多相關ES多條件查詢內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章: