登录
首页 >  Golang >  Go问答

如何使用mongodb/mongo-go-driver进行高效分页

来源:stackoverflow

时间:2024-04-27 14:21:37 224浏览 收藏

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进行高效分页》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

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