登录
首页 >  Golang >  Go问答

索引中的文档数量的获取方法

来源:stackoverflow

时间:2024-03-28 21:45:29 118浏览 收藏

亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《索引中的文档数量的获取方法》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下,希望所有认真读完的童鞋们,都有实质性的提高。

问题内容

使用的库: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())

今天关于《索引中的文档数量的获取方法》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>