0
Я посылаю этот запрос на ES:ElasticSearch термин агрегация на поля даты
{
"aggregations" : {
"followUpActivity.metainfo.metainfos.date1" : {
"terms" : {
"field" : "metainfos.date1",
"missing" : "2016-07-20T13:59:06.208Z",
"order" : {
"_count" : "desc"
}
}
}
}
}
Это результат:
{
"took":1,
"timed_out":false,
"_shards":{
"total":1,
"successful":1,
"failed":0
},
"hits":{
"total":5,
"max_score":1.0,
"hits":[
{
"_index":"living_v1",
"_type":"fuas",
"_id":"4a4137ec-48fe-11e6-9f47-30b5c2122322",
"_score":1.0,
"_routing":"living_team",
"_source":{
"user":"living_team",
"timestamp":"2016-07-13T15:04:15.548Z",
"metainfos":{
"string1":[
"s1",
"s2"
]
}
}
},
{
"_index":"living_v1",
"_type":"fuas",
"_id":"4d526f8d-48fe-11e6-9f47-30b5c2122322",
"_score":1.0,
"_routing":"living_team",
"_source":{
"user":"living_team",
"timestamp":"2016-07-13T15:37:24.471Z",
"metainfos":{
"string1":[
"s1",
"s2"
]
}
}
},
{
"_index":"living_v1",
"_type":"fuas",
"_id":"89fc1180-48fe-11e6-9f47-30b5c2122322",
"_score":1.0,
"_routing":"living_team",
"_source":{
"user":"living_team",
"timestamp":"2016-07-13T13:43:18.566Z",
"metainfos":{
"string1":[
"s3"
]
}
}
},
{
"_index":"living_v1",
"_type":"fuas",
"_id":"7168393b-4daf-11e6-83ba-30b5c2122322",
"_score":1.0,
"_routing":"living_team",
"_source":{
"user":"living_team",
"timestamp":"2016-07-19T14:04:14.175Z",
"metainfos":{
"date1_ldate":[
"2016-07-19T12:59:55.442Z" <<<<<<<<<<<<<<<<<<<<<<
]
}
}
},
{
"_index":"living_v1",
"_type":"fuas",
"_id":"7af3f44f-48fe-11e6-9f47-30b5c2122322",
"_score":1.0,
"_routing":"living_team",
"_source":{
"user":"living_team",
"timestamp":"2016-07-13T14:18:49.328Z",
"metainfos":{
"string1":[
"s2"
],
"num1":[
12.0,
13.0
],
"date1_ldate":[
"2016-07-19T13:04:55.467Z", <<<<<<<<<<<<<<<<<
"2016-07-20T12:44:32.116Z" <<<<<<<<<<<<<<<<<
]
}
}
}
]
},
"aggregations":{
"followUpActivity.metainfo.metainfos.date1":{
"doc_count_error_upper_bound":0,
"sum_other_doc_count":0,
"buckets":[
]
}
}
}
Как вы можете видеть metainfos.date1_ldate
сообщается на двух документах, однако ведер результат пуст.
Что я делаю неправильно?
Извините! Как вы можете догадаться, я строю этот запрос с помощью Java API. После того, как я изменил свою орфографическую ошибку, я понял, что ES Java API возвращает «LongTerms» вместо какого-то «DateTerms». Знаете ли вы, как я должен бороться с этим агрегатом LongTerms, чтобы получить мои даты? – Jordi
Hm ... внутренне ES хранит даты как временные метки, что означает длинное числовое значение. От взгляда на [исходный код «LongTerms»] (https://github.com/elastic/elasticsearch/blob/master/core/src/main/java/org/elasticsearch/search/aggregations/bucket/terms/LongTerms .java # L33) Я вижу намерение использовать его, как вы его видите, - для полей даты. Так что это ожидаемое поведение. Я предлагаю кастинг на 'java.util.Date' с [одним из конструкторов, которые могут получить' long'] (https://docs.oracle.com/javase/7/docs/api/java/sql/Date. HTML # Дата (длинный)). –
Я вижу. Mmm, есть ли способ проверить, является ли источник длинного значения ведра датой или длинным? – Jordi