8.15学习笔记|青训营

21 阅读2分钟

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