在elasticsearch中,有時會想要經過索引日期來篩選查詢的數據,此時就須要用到日期數學表達式。
更多內容參考Elasticsearch翻譯彙總html
模式以下:curl
<static_name{date_math_expr{date_format|time_zone}}>
其中各個字段含義爲:elasticsearch
須要注意的是,在使用時要把索引以及日期表達式的部分放在< >
尖括號內。ide
好比如今的時間是2024年3月22日中午12點.utc
ui
注意,若是是中國的時間須要加上8個小時!編碼
表達式 | 表示的值 |
---|---|
<test-{now/d}> |
test-2024.03.22 |
<test-{now/M}> |
test-2024.03.01 |
<test-{now/M{YYYY.MM}}> |
test-2024.03 |
<test-{now/M-1M{YYYY.MM}}> |
test-2024.02 |
<test-{now/d{YYYY.MM.dd\|+12:00}}> |
test-2024.03.23 |
在數學日期表達式中,now就是如今的時間,好比,我寫下這篇博客的時間是2016.03.17 20:39:00
。url
2016.03.17 00:00:00
。2016.03.01 00:00:00
它還支持加減法,好比翻譯
2016.03.17 21:39:00
2016.03.16 20:39:00
瞭解日期表達式的用法,在使用elasticsearch時是很必要的。code
curl -XPOST 'localhost:9200/<test-\{now%2FM\}>/type/1?pretty' -d '{"name":"xing1",age:20}' { "_index" : "test-2016.03.01", "_type" : "type", "_id" : "1", "_version" : 1, "_shards" : { "total" : 2, "successful" : 1, "failed" : 0 }, "created" : true }
注意:orm
/
必須通過編碼才行使用起來跟索引數據時同樣。
curl -XPOST 'localhost:9200/<test-\{now%2FM\}>/_search?pretty' -d '{"query":{"match_all":{}}}' { "took" : 120, "timed_out" : false, "_shards" : { "total" : 5, "successful" : 5, "failed" : 0 }, "hits" : { "total" : 1, "max_score" : 1.0, "hits" : [ { "_index" : "test-2016.03.01", "_type" : "type", "_id" : "1", "_score" : 1.0, "_source" : { "name" : "xing1", "age" : 20 } } ] } }
在全部帶有index的API中,都支持上面的用法。