参考——李文周的博客
什么是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()
db.AutoMigrate(&Userinfo{})
u := Userinfo{}
db.First(&u)
fmt.Printf("u:%#v\n",u)
db.Model(&u).Update("hobby","NBA2K")
db.Delete(&u)
}
我们可以简单归纳一下Go语言里面结构体和数据库的对应关系:
- 结构体——数据库表(Demo里的Userinfo其实就是数据库里表名为Userinfo的一张表)
- 结构体实例/对象——数据库行数据(Demo代码里的u1和u其实就是userinfo表里的一行数据)
- 结构体字段——数据库表字段(u1里面的id,name其实对应着表里面的id,name)
我们对上面的每一次操作都去终端里看一下执行结果,查看是否和我们计划一样
|