Gorm
Gorm是golang的一个orm框架,它提供了对数据库操作的封装,使用起来相当便利。
但在项目开发中,代码写的多了,还是发现在它之上还是有再次封装的空间,比如说添加错误日志、或者是一些使用频率非常高的对单个表的条件查询、分页查询、数据更新等。
默认情况下,GORM 会使用ID作为表的主键;
可以通过标签gorm:"primaryKey"
将某个字段设为主键;
使用结构体名的 snake_case 作为表名, 譬如UserAssets,在数据库中为user_assets,表名结尾自动添加字母s,如单词以s结尾则不添加;
如果结构体名转为snake_case形式后的表格不存在,那么需显式指定表名,譬如db.Table("User").Create(user);
gorm内置gorm.Model结构体,提供字ID、CreatedAt、UpdatedAt、DeletedAt,此结构体可以被其他结构体所内置使用;
gorm默认使用CreatedAt、UpdatedAt追踪创建/更新时间。如果定义了这两个字段,GORM 在创建、更新时会自动填充
特点:
- 全功能ORM;
- 关联(包含一个,包含多个,属于,多对多,多种包含);
- Callbacks(创建/保存/更新/删除/查找之前/之后);
- 预加载;
- 事务
- 复合主键
- SQL Builder
- 自动迁移
- 日志
- 可扩展,编写基于GORM回调的插件
- 每个功能都有测试
- 开发人员友好
连接数据库
GORM 官方支持的数据库类型有: MySQL, PostgreSQL, SQlite, SQL Server
package main
import (
"gorm.io/driver/mysql"
"gorm.io/gorm"
)
func main() {
// 用户名:密码@tcp(ip:port)/数据库?charset=utf8mb4&parseTime=True&loc=Local
dsn := "root:root123@tcp(127.0.0.1:3306)/test_gorm?charset=utf8mb4&parseTime=True&loc=Local"
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
if err != nil {
panic(err)
}
// 释放连接
// db.Close() // 没有这个方法了???
}
数据操作
简单的添加数据 & 查询数据 & 更新数据 & 删除数据
package main
import (
"fmt"
"gorm.io/driver/mysql"
"gorm.io/gorm"
)
type User struct {
Id int
Name string
Age int
Addr string
Pic string
}
func main() {
dsn := "root:root123@tcp(127.0.0.1:3306)/test_gorm?charset=utf8mb4&parseTime=True&loc=Local"
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
if err != nil {
panic(err)
}
// 自动迁移
db.Set("gorm:table_options", "ENGINE=InnoDB").AutoMigrate(&User{})
// 增
db.Create(&User{
Name: "张三",
Age: 18,
Addr: "北京市",
Pic: "/static/img.png",
})
// 查
var user User
db.First(&user)
fmt.Println(user) // {1 张三 18 北京市 /static/img.png}
// 改
user.Name = "lisi"
db.Save(&user)
fmt.Println(user) // {1 lisi 18 北京市 /static/img.png}
// 删
db.Delete(&user)
}