当前位置: > > > > 如何使用mongodb/mongo-go-driver进行高效分页
如何使用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进行高效分页》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注米云公众号吧!
