文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

【Gin】Gin 使用 GORM 操作 MySQL 数据库

2023-09-02 10:02

关注

文章目录


作者的 Gin 框架学习是根据 B站视频 Gin教程_Golang框架Gin入门实战教程 来学习的,对大地老师的评价不吹不捧,很喜欢其讲课风格,而且这个视频特别适合小白学习,强烈推荐。

GORM

⭐️GORM 介绍

官网:https://gorm.io/

GORM 是Golang 的一个 orm 框架。ORM 就是通过实例对象的语法,完成关系数据库的操作的技术,是“对象-关系映射”(Object-Relational Mapping)的缩写。使用 orm 框架可以让我们更方便的操作数据库。

GORM 支持的数据库类型有:MySQL、PostgreSQL、SQlite、SQL Server

特性(摘自官网)

⭐️Gin 当中使用 GORM

安装
如果使用 go mod 管理项目的话可以忽略此步骤

go get -u gorm.io/gormgo get -u gorm.io/driver/mysql

Gin 当中使用 GORM 连接数据库
在 models 下新建 core.go 建立数据库连接

package modelsimport ("fmt""gorm.io/driver/mysql""gorm.io/gorm")var DB *gorm.DBvar err errorfunc init() {// 参考 https://github.com/go-sql-driver/mysql#dsn-data-source-name 获取详情dsn := "root:123456@tcp(127.0.0.1:3306)/gin?charset=utf8mb4&parseTime=True&loc=Local"DB, err = gorm.Open(mysql.Open(dsn), &gorm.Config{})if err != nil {fmt.Println(err)}}

定义操作数据库的模型(相当于 Java 当中的实体类)

定义数据库模型注意以下几点:

结构体的名称必须首字母大写。并和数据库表名称对应。例如:表名称为 user 结构体名称定义为 User,表名称为 article_cate 的结构体名称定义为 ArticleCate。

结构体当中的字段名称首字母必须大写。并和数据库表中的字段一一对应。例如:下面结构体中的 Id 和数据库中的 id 对应,Username 和数据库中的 username 对应,Age 和数据库中的 age 对应,Email 和数据库中的 email 对应,AddTime 和数据库中的 add_time 字段对应。

默认情况表名是结构体名称的复数形式。如果我们的结构体名称定义为 User ,表示这个模型默认操作的是 users 表。

我们可以使用结构体中的自定义方法 TableName 改变结构体的默认表名称

func (user User) TableName() string{return "user"}

定义 user 模型

package modelstype User struct {Id       intUsername stringAge      intEmail    stringAddTime  int}// TableName 表示配置操作数据库的表名称func (user User) TableName() string {return "user"}

⭐️CRUD

找到要操作数据库表的控制器,然后引入 models 模块

package adminimport ("Gin_demo/models""fmt""github.com/gin-gonic/gin""net/http""path")type UserController struct {BaseController}func (con UserController) Index(c *gin.Context) {// 查询数据库// 查询年龄大于20的用户userList := []models.User{}models.DB.Where("age>20").Find(&userList)c.JSON(http.StatusOK, gin.H{"result": userList,})}func (con UserController) Add(c *gin.Context) {user := models.User{Username: "zhaoliu",Age:      25,Email:    "111@qq.com",AddTime:  int(models.GetUnix()),}models.DB.Create(&user)c.String(http.StatusOK, "增加数据成功!")fmt.Println("user==>", user)}func (con UserController) Edit(c *gin.Context) {// 保存所有字段// 查询 id 等于 6 的数据user := models.User{}models.DB.Where("id=?", 1).Find(&user)user.Username = "haha"user.AddTime = int(models.GetUnix())models.DB.Save(&user)c.JSON(http.StatusOK, gin.H{"result": user,})}func (con UserController) Delete(c *gin.Context) {user := models.User{}models.DB.Where("id=?", 4).Delete(&user)c.String(200, "删除成功")}

⭐️查询语句详解

https://gorm.io/zh_CN/docs/query.html

package adminimport ("Gin_demo/models""github.com/gin-gonic/gin")type NavJSON struct {Id    int    `json:"id"`Title string `json:"title"`}type NavController struct {BaseController}func (j NavJSON) TableName() string {return "nav"}func (con NavController) Index(c *gin.Context) {// 查询全部数据// 查询单条数据// 查询id大于3的数据// 查询id大于3 AND id小于6的数据// 使用in 查询id 在 3 5 6 当中的数据// like// between and// Or// 使用 Select 指定返回的字段// 排序// 分页// CountnavList := []models.Nav{}var num int64models.DB.Find(&navList).Count(&num)c.JSON(200, gin.H{"result": num,})}

⭐️查看执行的 sql 语句

package modelsimport ("fmt""gorm.io/driver/mysql""gorm.io/gorm""gorm.io/gorm/logger""gorm.io/gorm/schema")var DB *gorm.DBvar err errorfunc init() {// 参考 https://github.com/go-sql-driver/mysql#dsn-data-source-name 获取详情dsn := "root:123456@tcp(127.0.0.1:3306)/gin?charset=utf8mb4&parseTime=True&loc=Local"DB, err = gorm.Open(mysql.Open(dsn), &gorm.Config{Logger: logger.Default.LogMode(logger.Info),NamingStrategy: schema.NamingStrategy{SingularTable: true,},})if err != nil {fmt.Println(err)}}

来源地址:https://blog.csdn.net/JN_HoweveR/article/details/129823463

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯