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

Golang *** 作MySQL(一)——用gorm实现curd,第1张

参考——李文周的博客

什么是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语言里面结构体和数据库的对应关系:

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

我们对上面的每一次 *** 作都去终端里看一下执行结果,查看是否和我们计划一样

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/994762.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存