参考——李文周的博客
什么是GORMGORM是一个go语言开发的ORM框架,ORM全称是Object-Relationship-Mapping,像Java中经常用到的MyBatis就是一个ORM框架,而GORM也是一样,大大降低了对开发人员的sql语句能力,开发人员只需要调用框架中的api即可,剩下的由GORM框架将代码转换成SQL语句后,对数据库进行 *** 作
优点:对开发人员友好,大大提高了开发效率
缺点:
1.牺牲了程序性能
2.弱化了开发人员的sql能力的能力
我们只需要在Goland的终端里依次运行下面两行命令,即可在IDE里使用GORM了
(我这里使用的数据库是mysql,所以第二个命令下载的driver是mysql的)
go get -u github.com/jinzhu/gorm
go get github.com/jinzhu/gorm/dialects/mysql@v1.9.16
这两行命令运行完成之后,任务其实已经完成了一半
如果不会安装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)我们对上面的每一次 *** 作都去终端里看一下执行结果,查看是否和我们计划一样
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)