文章目录
- gorm基本使用
- 连接数据库
- 表操作
- 创建表
- 删除表
- 增删改查
- 插入数据
- 查询数据
- 更新数据
- 删除内容
gorm基本使用
gorm框架是go的一个数据库连接及交互框架,一般用于连接关系型数据库。
安装gorm,使用命令安装:
go get -u -v github.com/jinzhu/gorm
连接数据库
构建连接的目标为数据库中某一个库,同大多数框架一样使用url进行连接,url基本格式:
用户名:密码@连接方式(ip:port)/数据库名?参数
用户名:连接数据库用户名
密码:连接数据库密码
连接方式:或称为访问协议,一般为tcp
ip:数据库所在服务器地址
port:数据库监听端口
数据库名:数据库中对应要连接库名
参数:附加数据库参数,根据数据库不同内容不同
确定url后,就可以调用gorm中参数进行连接数据库操作:
//调用Open函数连接数据库,第一个参数为对应数据库名称,这里以mysql为例,mariadb也可以使用mysql作为名称。第二个参数为刚才设置好的url。
//得到两个结果:第一个为连接后对象,用于操作数据库对象;第二个为错误信息,连接失败会返回内容,连接成功返回nil,空。
dbConn, err := gorm.Open("mysql", "root:123456@tcp(127.0.0.1:3306)/test1?charset=utf8&parseTime=True&loc=Local")
if err != nil {
panic(err)
}
别忘记import语句导入包:
// gorm包
"github.com/jinzhu/gorm"
//数据库方言,因为不会直接使用,所以前面要加下划线
_ "github.com/jinzhu/gorm/dialects/mysql"
操作完数据库后不要忘了关闭连接:
dbConn.Close()
表操作
创建表
gorm创建表基于结构体,所以创建表前要先用结构体规划表结构,这里简单写一个结构体,创建表时默认结构体第一个字段作为主键:
type User struct {
Id int
Name string
Data string
}
写好结构体后,调用创建表语句直接按照结构体结构创建表:
// 直接创建表
dbConn.CreateTable(&User{})
// 自定义表名创建表
dbConn.Table("user").Create(&User{})
当直接创建表时,表名遵循规范:
1、大写字母全部小写,所有位于中间的大写字母都变成小写字母并且前面加下划线,例如UserInfo结构体创建为表名称为user_infos。
2、上面最后的那个s是因为直接创建表时,名称最后都会加上一个s。所以上面结构体User创建表后名称为users。
删除表
// 按照结构体删除,即默认表名
dbConn.DropTable(&User{})
//按照表名删除,可为自定义的表名
dbConn.DropTable("user")
增删改查
插入数据
插入数据,插入数据方法结构使用Create方法:
// 默认表名插入数据
dbConn.Create(&User{Id: 1, Name: "awda", Data: "ssss"})
// 自定义表名插入数据
dbConn.Table("user").Create(&User{Id: 1, Name: "awda", Data: "ssss"})
查询数据
查询第一条找到的数据,使用First,该方法返回值仍然为db对象,所以接收数据时我们需要先定义一个对应表结构的结构体接收数据:
//定义user的结构体对象
var user User
// 还是两种操作方式
//其中&user代表上面定义的结构体对象用于接收数据,使用时通过上面变量直接操作
//默认查询的话相当于查询第一条数据
dbConn.First(&user)
dbConn.Table("user").First(&user)
//输出内容
fmt.Print(user.Id)
//带条件查询
//只传入一个参数时代表默认查询主键
dbConn.First(&user, 1)
dbConn.Table("user").First(&user, 1)
//也可以指定查询条件,条件书写格式与普通sql语句并无不同,其中?代表占位符,First方法是动态参数方法,可以传入任意参数,将按照?占位符逐个传入。
dbConn.First(&user, "name=? and id = ?", "awda", 1)
dbConn.Table("user").First(&user, "name=? and id = ?", "awda", 1)
有First就有Last,同First调用格式一致。
批量查询,批量查询使用Find方法,其余参数结构同First或Last相同,只不过传参时一般传入数组参数,当然,First或Last方法也可以传入数组参数,但得到的数组只有一个数据,批量查询操作:
//定义结构体数组接收批量数据
var user[] User
//其余操作与之前相同,不再过度演示
dbConn.Find(&user)
dbConn.Table("user").Find(&user)
更新数据
//根据Where语句更新
//更新单个字段
dbConn.Table("user").Where("id=?", 1).Update("id", 1234)
//更新批量字段
dbConn.Table("user").Where("id=?",2).Updates(&User{Id: 123, Name: "awdawd1231"})
//按主键更新,传入结构体对象,根据对应主键更新相应内容
dbConn.Table("user").Save(&user1)
删除内容
//按照主键删除
dbConn.Table("user").Delete(&user1)
//指定条件删除,后面需要指定一个空指针,因为Delete方法必须有参数
dbTable("user").Where(条件表达式).Delete(&User{})
//传入空指针代表指定结构,按照默认表名去删除其中内容
db.Where(条件表达式).Delete(&User{})