亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《索引中的文档数量的获取方法》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下,希望所有认真读完的童鞋们,都有实质性的提高。
问题内容使用的库:https://pkg.go.dev/github.com/olivere/elastic/v7
res, _ := orm.Es.Search("pk").Do(context.Background())
fmt.Println("res",res.TotalHits()) // output:10000
count: 3628800 查询的数量只有10000,如何得到总数?
解决方案
尝试将 track_total_hits
搜索选项设置为 true
。
通常,如果不访问所有匹配项,就无法准确计算总命中数,这对于匹配大量文档的查询来说成本高昂。 track_total_hits 参数
允许您控制如何跟踪点击总数。鉴于通常有一个命中数下限就足够了,例如“至少有 10000 个命中”,因此默认设置为 10,000。这意味着请求将准确计算总点击数,最多可达 10,000 次点击。如果您不需要特定阈值后的准确点击次数,那么加快搜索速度是一个很好的权衡。
设置为 true 时,搜索响应将始终跟踪与查询准确匹配的命中数
官方文档中有一个 great article 描述了它是什么。
通过调用 tracktotalhits
方法在代码中启用它:
res, _ := orm.es.search("pk").tracktotalhits(true).do(context.background())
或者,如果您只需要总数,只需使用 Count API:
res, _ := orm.Es.Count("pk").Do(context.Background())
今天关于《索引中的文档数量的获取方法》的内容介绍就到此结束,如果有什么疑问或者建议,可以在编程网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!