Golang使用Gin、GORM和MySQL进行三层架构

本文介绍了如何使用Gin、GORM和MySQL在Golang中构建三层架构的CRUD应用。主要内容包括创建Model结构体、Repository接口及实现、Service接口及实现以及Controller。GORM在应用程序退出时会自动关闭数据库连接,但在长期运行的服务中,建议手动关闭以释放资源。
摘要由CSDN通过智能技术生成

学习目标:

1.学习使用Gin和GORM结合

2. 学习Golang 中的三层构架


学习内容:

当使用Golang的Gin、GORM和MySQL进行三层架构的CRUD操作时,你可以按照以下步骤进行:

1. 创建Model结构体:


首先,创建一个`models`文件夹,并在其中创建一个名为`member.go`的文件。在该文件中定义`Member`结构体,代表数据库中的`member`表,同时添加GORM的标签来映射字段和表格。

package models

import "time"

type Member struct {
    ID        uint      `gorm:"primary_key"`
    Name      string    `gorm:"type:varchar(100);not null"`
    Email     string    `gorm:"type:varchar(100);unique;not null"`
    CreatedAt time.Time `gorm:"not null&#
好的,我可以帮您实现这个功能。首先,我需要确认一下您的开发环境是否已经准备好了,包括 Go 编译器和相关的依赖库。 接下来,我将为您提供一个简单的代码示例,用于创建一个 API 服务并实现用户信息的增删改查功能。同时,该示例还包含了图片上传的功能,使用Gin 框架和 GORM ORM 库。 以下是示例代码: ```go package main import ( "fmt" "net/http" "os" "github.com/gin-gonic/gin" "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql" ) type User struct { gorm.Model Name string `json:"name"` Gender string `json:"gender"` Description string `json:"description"` Avatar string `json:"avatar"` } func main() { // 初始化数据库连接 db, err := gorm.Open("mysql", "user:password@tcp(127.0.0.1:3306)/database?charset=utf8mb4&parseTime=True&loc=Local") if err != nil { fmt.Println("database connect error:", err) os.Exit(1) } defer db.Close() // 创建用户表 db.AutoMigrate(&User{}) // 创建 Gin 实例 router := gin.Default() // 添加用户接口 router.POST("/users", func(c *gin.Context) { // 解析请求参数 var user User if err := c.BindJSON(&user); err != nil { c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) return } // 保存用户信息 if err := db.Create(&user).Error; err != nil { c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()}) return } c.JSON(http.StatusOK, user) }) // 查询用户接口 router.GET("/users/:id", func(c *gin.Context) { // 获取用户 ID id := c.Param("id") // 查询用户信息 var user User if err := db.First(&user, id).Error; err != nil { c.JSON(http.StatusNotFound, gin.H{"error": err.Error()}) return } c.JSON(http.StatusOK, user) }) // 更新用户接口 router.PUT("/users/:id", func(c *gin.Context) { // 获取用户 ID id := c.Param("id") // 查询用户信息 var user User if err := db.First(&user, id).Error; err != nil { c.JSON(http.StatusNotFound, gin.H{"error": err.Error()}) return } // 解析请求参数 var updateUser User if err := c.BindJSON(&updateUser); err != nil { c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) return } // 更新用户信息 user.Name = updateUser.Name user.Gender = updateUser.Gender user.Description = updateUser.Description user.Avatar = updateUser.Avatar if err := db.Save(&user).Error; err != nil { c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()}) return } c.JSON(http.StatusOK, user) }) // 删除用户接口 router.DELETE("/users/:id", func(c *gin.Context) { // 获取用户 ID id := c.Param("id") // 删除用户信息 if err := db.Delete(&User{}, id).Error; err != nil { c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()}) return } c.JSON(http.StatusOK, gin.H{"message": "delete success"}) }) // 上传图片接口 router.POST("/upload", func(c *gin.Context) { // 从请求中获取文件 file, err := c.FormFile("file") if err != nil { c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) return } // 保存文件到本地 filename := fmt.Sprintf("uploads/%s", file.Filename) if err := c.SaveUploadedFile(file, filename); err != nil { c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()}) return } c.JSON(http.StatusOK, gin.H{"url": filename}) }) // 启动服务 router.Run(":8080") } ``` 在这个示例中,我们首先定义了一个 User 结构体,包含了我们要存储的用户信息。然后,我们使用 GORM 库创建了一个数据库连接,并在其中创建了一个用户表。 接着,我们使用 Gin 框架创建了四个 API 接口,分别用于添加、查询、更新和删除用户信息。其中,添加、更新和查询用户信息的接口都使用了 BindJSON 方法来解析请求参数,并使用 GORM 库来持久化用户信息到数据库中。 最后,我们还添加了一个用于上传图片的接口,使用Gin 框架的 FormFile 方法来获取上传的文件,并使用 SaveUploadedFile 方法将文件保存到本地。 请注意,由于这个示例中的数据库连接字符串中包含了敏感信息,因此在实际使用中,您需要将其替换为您自己的数据库连接字符串。 希望这个示例能够帮助到您,如果您有任何问题或需要进一步的帮助,请随时提出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

田猿笔记

写文章不容易,希望大家小小打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值