我正在 elasticsearch 中执行查询。我需要获得索引中表示的每个月的属性“end_date_ut”(类型为 Date,格式为 dateOptionalTime)的点击次数。为此,我使用 date_histogram 聚合。
我的查询如下:
GET inc/_search
{
"size": 0,
"aggs": {
"appli": {
"date_histogram": {
"field": "end_date_ut",
"interval": "month"
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
这是结果的一部分:
"hits": {
"total": 517478,
"max_score": 0,
"hits": []
},
"aggregations": {
"appli": {
"buckets": [
{
"key_as_string": "2009-08-01T00:00:00.000Z",
"key": 1249084800000,
"doc_count": 0
},
{
"key_as_string": "2009-09-01T00:00:00.000Z",
"key": 1251763200000,
"doc_count": 1
},
{
"key_as_string": "2009-10-01T00:00:00.000Z",
"key": 1254355200000,
"doc_count": 2362
},
{
"key_as_string": "2009-11-01T00:00:00.000Z",
"key": 1257033600000,
"doc_count": 5336
},
{
"key_as_string": "2009-12-01T00:00:00.000Z",
"key": 1259625600000,
"doc_count": 7536
},
{
"key_as_string": "2010-01-01T00:00:00.000Z",
"key": 1262304000000,
"doc_count": 8864
}
Run Code Online (Sandbox Code Playgroud)
问题是我有太多的桶(结果)。当我使用“术语聚合”时,我没有任何问题,因为我可以设置大小,但使用“日期直方图聚合”时,我找不到方法来限制查询结果。
小智 8
{
"size": 0,
"aggs": {
"by_minute": {
"date_histogram": {
"field": "createTime",
"interval": "1m",
"order": {
"_count": "desc"
}
},
"aggs": {
"top2": {
"bucket_sort": {
"sort": [],
"size": 2
}
}
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
{
"took": 28,
"timed_out": false,
"_shards": {
"total": 2,
"successful": 2,
"skipped": 0,
"failed": 0
},
"hits": {
"total": 999999,
"max_score": 0.0,
"hits": []
},
"aggregations": {
"by_minute": {
"buckets": [
{
"key_as_string": "2019-12-21T16:13:00.000Z",
"key": 1576944780000,
"doc_count": 6374
},
{
"key_as_string": "2019-12-21T16:10:00.000Z",
"key": 1576944600000,
"doc_count": 6327
}
]
}
}
}
Run Code Online (Sandbox Code Playgroud)
Val*_*Val -1
我建议min_doc_count
仅包含有数据的存储桶,即具有 0 个文档的存储桶不会在响应中返回。
GET inc/_search
{
"size": 0,
"aggs": {
"appli": {
"date_histogram": {
"field": "end_date_ut",
"interval": "month",
"min_doc_count": 1 <--- add this
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
如果可以的话,您还可以添加range
查询以限制运行聚合的时间间隔。
归档时间: |
|
查看次数: |
3788 次 |
最近记录: |