优秀的编程知识分享平台

网站首页 > 技术文章 正文

gorm基本使用(gormfaobhar)

nanyue 2024-09-09 04:57:38 技术文章 7 ℃

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{})

Tags:

最近发表
标签列表