有没有 elasticsearch 熟悉的大佬,分组聚合分页的问题
資深大佬 : dyllen 3
实现类似 SQL 里面 group by 分组去重之后分页输出列表。
我的做法如下:
- 获取当前页的数据列表
用的是composite
桶聚合获取一页的数据,下一页用after
参数。
获取到一页数据列表之后,拿到 id 列表再去主表里面查询具体的数据。
agg 部分:
'aggs' => [ 'uid' => [ 'composite' => [ 'size' => 20, 'sources' => [ [ 'uid' => [ 'terms' => [ 'field' => 'uid', 'order' => 'desc', ], ], ], ], ], ]
用 uid 聚合和排序
- 获取数据总数
用的cardinality
和sum_bucket
组和。
聚合之后在计算桶的总数,size 设置一个比较大的数。
agg 部分:
'aggs' => [ 'uid' => [ 'terms' => [ 'field' => 'uid', 'size' => 5000, ], 'aggs' => [ 'uid_count' => [ 'cardinality' => [ 'field' => 'uid', ], ], ], ], 'sun_uid' => [ 'sum_bucket' => [ 'buckets_path' => 'uid>uid_count', ], ], ]
方法对不对呀?总感觉 es 做分页列表输出不是太好,只能获取下一页。
ui 需求分页需求是可以跳页,随便点哪页的,用 es 的话,一般怎么满足的?还是说满足不来,只能改需求了。
大佬有話說 (5)