2016-07-20 2 views
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 сообщается на двух документах, однако ведер результат пуст.

Что я делаю неправильно?

ответ

0

Название поля date1_ldate не date1. Итак, вам нужно "terms" : { "field" : "metainfos.date1_ldate".

+0

Извините! Как вы можете догадаться, я строю этот запрос с помощью Java API. После того, как я изменил свою орфографическую ошибку, я понял, что ES Java API возвращает «LongTerms» вместо какого-то «DateTerms». Знаете ли вы, как я должен бороться с этим агрегатом LongTerms, чтобы получить мои даты? – Jordi

+0

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 # Дата (длинный)). –

+0

Я вижу. Mmm, есть ли способ проверить, является ли источник длинного значения ведра датой или длинным? – Jordi

Смежные вопросы