go 实现分页 gin grom

var total int
page,_          := strconv.Atoi(c.DefaultQuery("page","1"))
pageSize,_  := strconv.Atoi(c.DefaultQuery("pageSize","10"))

db := database.Student
db = db.Model(course.Student{})
    
if err := db.Count(&total).Error; err != nil{
    c.JSON(http.StatusOK, gin.H{
        "code" : 500,
        "message" : "查询数据异常",
    })
    return
}

offset := (page-1)*pageSize
if err := db.Order("id desc").Limit(pageSize).Offset(offset).Find(&data).Error;err != nil{
    c.JSON(http.StatusOK, gin.H{
        "code" : 500,
        "message" : "查询数据异常",
    })
    return
}

c.JSON(http.StatusOK, gin.H{
    "code":    200,
    "message": "success",
    "data"   : map[string]interface{}{
        "data" : rs,
        "total": total,
        "page" : page,
        "pageSize": pageSize,
    },
})
return

你可能感兴趣的:(go 实现分页 gin grom)