Golang操作MySQL(一)——用gorm实现curd

参考——李文周的博客

什么是GORM

GORM是一个go语言开发的ORM框架,ORM全称是Object-Relationship-Mapping,像Java中经常用到的MyBatis就是一个ORM框架,而GORM也是一样,大大降低了对开发人员的sql语句能力,开发人员只需要调用框架中的api即可,剩下的由GORM框架将代码转换成SQL语句后,对数据库进行操作

优点:对开发人员友好,大大提高了开发效率
缺点:
1.牺牲了程序性能
2.弱化了开发人员的sql能力的能力

如何在Goland中使用GORM

我们只需要在Goland的终端里依次运行下面两行命令,即可在IDE里使用GORM了
(我这里使用的数据库是mysql,所以第二个命令下载的driver是mysql的)

go get -u github.com/jinzhu/gorm
go get github.com/jinzhu/gorm/dialects/mysql@v1.9.16

在这里插入图片描述
在这里插入图片描述
这两行命令运行完成之后,任务其实已经完成了一半

使用Docker快速创建Mysql实例

如果不会安装MySQL或者懒得安装MySQL,可以使用一下命令快速运行一个MySQL8.0.19实例,当然前提是你要有docker环境(去官网下一个即可)

在本地的13306端口运行一个名为mysql8019,root用户名密码为root1234的MySQL容器环境:

docker run --name mysql8019 -p 13306:3306 -e MYSQL_ROOT_PASSWORD=root1234 -d mysql:8.0.19

然后再启动一个Mysql-client实例连接我们上面创建好的数据库环境,密码就是root1234

docker run -it --network host --rm mysql mysql -h127.0.0.1 -P13306 --default-character-set=utf8mb4 -uroot -p

在这里插入图片描述
运行完上面两行命令后,输入密码即可以使用Mysql了
在这里插入图片描述
输入密码之后,先创建一个名为db1的数据库

CREATE DATABASE DB1;

然后我们使用gorm连接DB1数据库进行CURD即可

package main

import (
	"fmt"
	"github.com/jinzhu/gorm"
	_"github.com/jinzhu/gorm/dialects/mysql"
)

type Userinfo struct {
	ID uint
	Name string
	Gender string
	Hobby string
}

func main()  {
	// 连接数据库
	db,err :=gorm.Open("mysql","root:root1234@(127.0.0.1:13306)/db1?charset=utf8mb4&parseTime=True&loc=Local")
	if err != nil{
		panic(err)
	}
	// 延迟关闭数据库
	defer db.Close()

	// 创建表 自动迁移(把结构体和数据表进行对应)
	// 比如我给USerinfo新增了一个字段,那么我们也会在数据库里添加对应的字段
	db.AutoMigrate(&Userinfo{})

	/* 1.创建数据行
	u1 := Userinfo{1,"zhl","male","gym"}
	db.Create(&u1)

	 */

	// 2.查询
	u := Userinfo{}
	db.First(&u) // 这个仅是其中一种查询方法,返回数据表第一行数据
	fmt.Printf("u:%#v\n",u)

	// 3.更新
	db.Model(&u).Update("hobby","NBA2K")

	// 4.删除
	db.Delete(&u)
}

我们可以简单归纳一下Go语言里面结构体和数据库的对应关系:

  1. 结构体——数据库表(Demo里的Userinfo其实就是数据库里表名为Userinfo的一张表)
  2. 结构体实例/对象——数据库行数据(Demo代码里的u1和u其实就是userinfo表里的一行数据)
  3. 结构体字段——数据库表字段(u1里面的id,name其实对应着表里面的id,name)

我们对上面的每一次操作都去终端里看一下执行结果,查看是否和我们计划一样
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值