Go語言結合Gin框架快速實現分頁查詢接口
在開發(fā) Web 應用時,分頁查詢 是非常常見的需求。比如文章列表、用戶管理后臺、商品展示頁,都需要分頁展示數據。
在 Go 語言中,我們可以結合 GORM + Gin 框架,快速實現分頁查詢接口。本文將帶你一步步實現一個 用戶列表的分頁接口。
一、環(huán)境準備
依賴庫安裝:
go get -u gorm.io/gorm go get -u gorm.io/driver/mysql go get -u github.com/gin-gonic/gin
數據庫使用 MySQL(也可換 SQLite、Postgres)。
二、定義用戶模型
我們以 User 模型作為例子:
package main
import (
"github.com/gin-gonic/gin"
"gorm.io/driver/mysql"
"gorm.io/gorm"
"log"
"net/http"
)
// User 用戶模型
type User struct {
ID uint `gorm:"primaryKey"`
Name string `gorm:"size:100"`
Email string `gorm:"unique"`
Age int
}
var db *gorm.DB
func initDB() {
dsn := "root:123456@tcp(127.0.0.1:3306)/testdb?charset=utf8mb4&parseTime=True&loc=Local"
var err error
db, err = gorm.Open(mysql.Open(dsn), &gorm.Config{})
if err != nil {
log.Fatal("數據庫連接失敗:", err)
}
// 自動遷移
_ = db.AutoMigrate(&User{})
}
三、實現分頁查詢接口
分頁查詢的核心就是 計算 offset 和 limit:
page當前頁(從 1 開始)pageSize每頁數量offset = (page - 1) * pageSize
代碼實現:
// 分頁查詢接口
func getUsers(c *gin.Context) {
// 獲取查詢參數,默認 page=1, pageSize=10
page := c.DefaultQuery("page", "1")
pageSize := c.DefaultQuery("pageSize", "10")
var (
users []User
total int64
)
// 轉換為 int
var p, ps int
fmt.Sscanf(page, "%d", &p)
fmt.Sscanf(pageSize, "%d", &ps)
if p < 1 {
p = 1
}
if ps < 1 {
ps = 10
}
// 查詢總數
db.Model(&User{}).Count(&total)
// 分頁查詢
db.Offset((p - 1) * ps).Limit(ps).Find(&users)
// 返回 JSON
c.JSON(http.StatusOK, gin.H{
"page": p,
"pageSize": ps,
"total": total,
"data": users,
})
}
在 main() 中注冊路由:
func main() {
initDB()
r := gin.Default()
r.GET("/users", getUsers)
r.Run(":8080")
}
四、接口調用效果
請求:
curl "http://localhost:8080/users?page=2&pageSize=5"
返回:
{
"page": 2,
"pageSize": 5,
"total": 23,
"data": [
{"ID":6,"Name":"Alice","Email":"alice@test.com","Age":22},
{"ID":7,"Name":"Bob","Email":"bob@test.com","Age":25},
{"ID":8,"Name":"Tom","Email":"tom@test.com","Age":20},
{"ID":9,"Name":"Jerry","Email":"jerry@test.com","Age":30},
{"ID":10,"Name":"Lucy","Email":"lucy@test.com","Age":19}
]
}
五、總結與優(yōu)化
本案例實現了一個 分頁查詢接口:
- 支持動態(tài)
page和pageSize參數 - 返回總數
total,便于前端計算總頁數 - 返回當前頁數據
優(yōu)化點:
1. 封裝通用分頁函數,避免每個接口都重復寫分頁邏輯。
2. 加入排序功能,如 orderBy=age desc。
3. 加入搜索過濾,例如按用戶名查詢。
這樣,我們就能快速實現一個完整的 分頁 + 搜索 + 排序 的列表接口。
到此這篇關于Go語言結合Gin框架快速實現分頁查詢接口的文章就介紹到這了,更多相關Go語言分頁查詢內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

