当前位置: > > > > 如何使用mongodb/mongo-go-driver进行高效分页
来源:stackoverflow
2024-04-27 14:21:37
0浏览
收藏
Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《如何使用mongodb/mongo-go-driver进行高效分页》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!
问题内容
我在下面的文章中读到,使用 _id
的自然顺序来执行分页会更有效,因为跳过总是从集合的开头开始。
mongodb 中快速高效的分页
// Page 1 db.students.find().limit(10) // Page 2 last_id = ... # logic to get last_id db.students.find({'_id': {'$gt': last_id}}).limit(10)
但我不知道如何使用 mongodb/mongo-go-driver
执行上述操作。
解决方案
你可以创建一个新的函数,不要忘记传递http.writer来读取参数。
func pagination(r *http.request, findoptions *options.findoptions) (int64, int64) { if r.url.query().get("page") != "" && r.url.query().get("limit") != "" { page, _ := strconv.parseint(r.url.query().get("page"), 10, 32) limit, _ := strconv.parseint(r.url.query().get("limit"), 10, 32) if page == 1 { findoptions.setskip(0) findoptions.setlimit(limit) return page, limit } findoptions.setskip((page - 1) * limit) findoptions.setlimit(limit) return page, limit } findoptions.setskip(0) findoptions.setlimit(0) return 0, 0 }
只要打电话
pagination(r, options)
示例
options := options.Find() page, limit := parameter.Pagination(r, options) // page, limit as response for header payload
理论要掌握,实操不能落!以上关于《如何使用mongodb/mongo-go-driver进行高效分页》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注公众号吧!