golang常用库之操作数据库的orm框架-gorm基本使用详解

【字号: 日期:2022-09-10浏览:27作者:雯心

golang常用库:gorilla/mux-http路由库使用golang常用库:配置文件解析库-viper使用golang常用库:操作数据库的orm框架-gorm基本使用

一:字段映射-模型定义

gorm中通常用struct来映射字段. gorm教程中叫模型定义

比如我们定义一个模型Model:

type User struct {gorm.ModelUserId int64 `gorm:'index'` //设置一个普通的索引,没有设置索引名,gorm会自动命名Birtheday time.Time Age int `gorm:'column:age'`//column:一个tag,可以设置列名称 Name string `gorm:'size:255;index:idx_name_add_id'`//size:设置长度大小,index:设置索引,这个就取了一个索引名Num int `gorm:'AUTO_INCREMENT'` Email string `gorm:'type:varchar(100);unique_index'`//type:定义字段类型和大小AddressID sql.NullInt64 `gorm:'index:idx_name_add_id'`IgnoreMe int `gorm:'_'`Description string `gorm:'size:2019;comment:’用户描述字段’'`//comment:字段注释Status string `gorm:'type:enum(’published’, ’pending’, ’deleted’);default:’pending’'`}

上面的gorm.Model 定义如下:

type Model struct { ID uint `gorm:'primary_key'`//primary_key:设置主键 CreatedAt time.Time UpdatedAt time.Time DeletedAt *time.Time}

当然我们也可以不用gorm.Model,自己定义一个差不多的类型如果你用ID,系统会自动设为表的主键,当然我们可以自己定义主键:比如:

// 使用`AnimalID`作为主键type Animal struct { AnimalID int64 `gorm:'primary_key'` Name string Age int64}

参考:https://gorm.io/zh_CN/docs/conventions.html

二:创建表

直接看下面的例子:createtable.go

package mainimport ('database/sql''fmt''github.com/jinzhu/gorm'_ 'github.com/jinzhu/gorm/dialects/mysql''time')type User struct {gorm.ModelUserId int64 `gorm:'index'`Birtheday time.TimeAge int `gorm:'column:age'`Name string `gorm:'size:255;index:idx_name_add_id'`Num int `gorm:'AUTO_INCREMENT'`Email string `gorm:'type:varchar(100);unique_index'`AddressID sql.NullInt64 `gorm:'index:idx_name_add_id'`IgnoreMe int `gorm:'_'`Description string `gorm:'size:2019;comment:’用户描述字段’'`Status string `gorm:'type:enum(’published’, ’pending’, ’deleted’);default:’pending’'`}//设置表名,默认是结构体的名的复数形式func (User) TableName() string {return 'VIP_USER'}func main() {db, err := gorm.Open('mysql', 'root:root@/gormdemo?charset=utf8&parseTime=True&loc=Local')if err != nil {fmt.Println('connect db err: ', err)}defer db.Close()if db.HasTable(&User{}) { //判断表是否存在db.AutoMigrate(&User{}) //存在就自动适配表,也就说原先没字段的就增加字段} else {db.CreateTable(&User{}) //不存在就创建新表}}

上面的gorm.Open()操作,如果想指定主机话,就需要加上括号 ()例如:

user:password@(localhost)/dbname?charset=utf8&parseTime=True&loc=Local

上面的程序中,先新建了一个数据库名叫gormdemo,然后运行:go run createtable.go , 成功运行后,数据库就会出现一张名为 vip_user 的表。

三:增删改查

新建一个gormdemo的数据库,然后执行下面的sql语句,就会建立一个animals的表,里面还有一些测试数据

CREATE TABLE `animals` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT ’galeone’, `age` int(10) unsigned DEFAULT ’0’, PRIMARY KEY (`id`)) ENGINE=MyISAM AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;-- ------------------------------ Records of animals-- ----------------------------INSERT INTO `animals` VALUES (’1’, ’demo-test’, ’20’);INSERT INTO `animals` VALUES (’2’, ’galeone’, ’30’);INSERT INTO `animals` VALUES (’3’, ’demotest’, ’30’);INSERT INTO `animals` VALUES (’4’, ’jim’, ’90’);INSERT INTO `animals` VALUES (’5’, ’jimmy’, ’10’);INSERT INTO `animals` VALUES (’6’, ’jim’, ’23’);INSERT INTO `animals` VALUES (’7’, ’test3’, ’27’);

增加

例子:create.go

package mainimport ('fmt''github.com/jinzhu/gorm'_ 'github.com/jinzhu/gorm/dialects/mysql')type Animal struct {ID int64Name stringAge int64}func main() {db, err := gorm.Open('mysql', 'root:root@/gormdemo?charset=utf8&parseTime=true&loc=Local')if err != nil {fmt.Println('connect db error: ', err)}defer db.Close()animal := Animal{Name: 'demo-test', Age: 20}db.Create(&animal)}

说明:上面的这个例子,自己在mysql中创建一个animals的数据表,字段为id,name,age

查找

select.go

package mainimport ('fmt''github.com/jinzhu/gorm'_ 'github.com/jinzhu/gorm/dialects/mysql')type Animal struct {ID int64Name stringAge int64}//https://gorm.io/zh_CN/docs/query.htmlfunc main() {db, err := gorm.Open('mysql', 'root:root@/gormdemo?charset=utf8&parseTime=true&loc=Local')if err != nil {fmt.Println('connect db error: ', err)}defer db.Close()//根据逐渐查询第一条记录var animal Animaldb.First(&animal)fmt.Println(animal)//根据逐渐查询最后一条记录var animal2 Animaldb.Last(&animal2)fmt.Println(animal2)//指定某条记录(仅当主键为整型时可用)var animal3 Animaldb.First(&animal3, 2)fmt.Println(animal3)//where条件//符合条件的第一条记录var animal4 Animaldb.Where('name = ?', 'demotest2').First(&animal4)fmt.Println('where : ', animal4, animal4.ID, animal4.Name, animal4.Age)//符合条件的所有记录var animals5 []Animaldb.Where('name = ?', 'galeone').Find(&animals5)fmt.Println(animals5)for k, v := range animals5 {fmt.Println('k:', k, 'ID:', v.ID, 'Name:', v.Name, 'Age:', v.Age)}//INvar animals6 []Animaldb.Where('name IN (?)', []string{'demo-test', 'demotest2'}).Find(&animals6)fmt.Println(animals6)//LIKEvar animals7 []Animaldb.Where('name like ?', '%jim%').Find(&animals7)fmt.Println(animals7)//ANDvar animals8 []Animaldb.Where('name = ? AND age >= ?', 'jim', '24').Find(&animals8)fmt.Println(animals8)//总数var count intvar animals9 []Animaldb.Where('name = ?', 'galeone').Or('name = ?', 'jim').Find(&animals9).Count(&count)fmt.Println(animals9)fmt.Println(count)//Scan, 原生查询var animals10 []Animaldb.Raw('SELECT id, name, age From Animals WHERE name = ? AND age = ? ', 'galeone', '30').Scan(&animals10)fmt.Println('Scan: ', animals10)//原生查询,select allvar animals11 []Animalrows, _ := db.Raw('SELECT id,name FROM Animals').Rows()//注意:上面的 select id,name 后面不能写成 * 代替,不然出来的结果都是默认0值//像这样结果: ALL: [{0 0} {0 0} {0 0} {0 0} {0 0} {0 0} {0 0}]//Scan 后面是什么字段,select 后面就紧跟什么字段for rows.Next() {var result Animalrows.Scan(&result.ID, &result.Name)animals11 = append(animals11, result)}fmt.Println('ALL: ', animals11)//output:ALL: [{1 demo-test 0} {2 galeone 0} {3 demotest2 0} {4 galeone 0} {5 galeone 0} {6 jim 0} {7 jimmy 0}]//select 查询var animal12 Animaldb.Select('name,age').Find(&animal12) //只查询name,age字段,相当于select name,age from userfmt.Println('select: ', animal12)// db.Select([]string{'name', 'age'}).Find(&animal12)// fmt.Println('select2: ', animal12)}

更新

update.go

package mainimport ('fmt''github.com/jinzhu/gorm'_ 'github.com/jinzhu/gorm/dialects/mysql')type Animal struct {ID int64Name stringAge int64}func main() {db, err := gorm.Open('mysql', 'root:root@/gormdemo?charset=utf8&parseTime=true&loc=Local')if err != nil {fmt.Println('connect db error: ', err)}defer db.Close()///根据一个条件更新//根据条件更新字段值,//后面加Debug(),运行时,可以打印出sqldb.Debug().Model(&Animal{}).Where('id = ? ', 4).Update('name', 'jimupdate')//UPDATE `animals` SET `name` = ’jimupdate’ WHERE (id = 4)//另外一种写法: 根据条件更新var animal Animalanimal = Animal{ID: 3}db.Debug().Model(animal).Update('name', 'demotest2update')// db.Debug().Model(&animal).Update('name', 'demotest2update') // 这种写法也可以//UPDATE `animals` SET `name` = ’demotest2update’ WHERE `animals`.`id` = 3/// 多个条件更新db.Model(&Animal{}).Where('id = ? AND age = ?', 4, 45).Update('name', 'jimupdate3')//UPDATE `animals` SET `name` = ’jimupdate2’ WHERE (id = 4 AND age = 45)/// 更新多个值db.Debug().Model(&Animal{}).Where('id = ?', 4).Update(Animal{Name: 'jim', Age: 90})// UPDATE `animals` SET `age` = 90, `name` = ’jim’ WHERE (id = 4)animal2 := Animal{ID: 5}db.Debug().Model(&animal2).Update(map[string]interface{}{'name': 'jimm', 'age': 100})//UPDATE `animals` SET `age` = 100, `name` = ’jimm’ WHERE `animals`.`id` = 5}

删除

delete.go

package mainimport ('fmt''github.com/jinzhu/gorm'_ 'github.com/jinzhu/gorm/dialects/mysql')type Animal struct {ID int64Name stringAge int64}func main() {db, err := gorm.Open('mysql', 'root:root@/gormdemo?charset=utf8&parseTime=true&loc=Local')if err != nil {fmt.Println('connect db error: ', err)}defer db.Close()db.Debug().Where('id = ?', 13).Delete(&Animal{})// DELETE FROM `animals` WHERE (id = 13)db.Debug().Delete(&Animal{}, 'id = ? AND age = ?', 14, 10)//DELETE FROM `animals` WHERE (id = 14 AND age = 10)}

四:Debug

在db后面直接加上 Debug(), 比如delete.go 里面的例子

五:参考

https://gorm.io/zh_CN/

到此这篇关于golang常用库之操作数据库的orm框架-gorm基本使用详解的文章就介绍到这了,更多相关golang gorm使用内容请搜索乐呵呵网以前的文章或继续浏览下面的相关文章希望大家以后多多支持乐呵呵网!

标签: Golang
相关文章: