在我开始使用 Elasticsearch 的时候,我希望获得给定查询的文档总数。比如我们想对数据进行分页显示。从 Elasticsearch 7.0之后,为了提高搜索的性能,在 hits 字段中返回的文档数有时不是最精确的数值。Elasticsearch 限制了最多的数值为10000。我们知道 Search API 提供的计数不准确,但后来我发现我可以通过 “track_total_hits” 参数获得这个结果。具体可以参考文章 “Elasticsearch:如何在搜索时得到精确的总 hits 数”
然而,通过进一步研究,我发现了一种更简单的方法来获取查询的实际文档数。
使用 Count API,我可以从查询中获取文档总数。
GET my_index/_count
{
"query": {
"range": {
"year": {
"gte": 1991
}
}
}
}
在我们的示例中,我们将获得 1991 年之后发布的文档总数。
{
"count": 634,
"_shards": {
"total": 1,
"successful": 1,
"skipped": 0,
"failed": 0
}
}
如你所见,响应大小紧凑,如果使用 Search API,它的结果则不同。另外,
文章来源:https://www.toymoban.com/news/detail-615805.html
这很好,因为通过网络传输的数据包较小,这对成本有积极影响。文章来源地址https://www.toymoban.com/news/detail-615805.html
到了这里,关于Elasticsearch:使用 count API 来获得所有文档的个数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!