Go语言之Gorm框架(一) ——初窥Gorm框架

Gorm和Mysql驱动的安装

打开终端,输入下列命令即可:

go get gorm.io/driver/mysql
go get gorm.io/gorm

Gorm连接数据库

示例

package main

import (
	"fmt"
	"github.com/sirupsen/logrus"
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
)

func init() {
	//数据库连接信息
	username := "root"
	password := "123456"
	databasename := "gorm"
	localHost := "localhost"
	port := 3306

	dns := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=utf8&parseTime=True&loc=Local",
		username, password, localHost, port, databasename)
	db, err := gorm.Open(mysql.Open(dns))
	if err != nil {
		logrus.Error("数据库连接失败", err)
	}
	fmt.Println("数据库连接成功", db)
}

func main() {
}

数据库连接的细节

  • 跳过默认事务
    为了保证数据一致性,Gorm会在事务中去执行去执行增删查改,如果我们没有这个需求可以选择跳过默认事务:
	db, err := gorm.Open(mysql.Open(dns),&gorm.Config{SkipDefaultTransaction: true})
  • 命名策略
    在grom中默认表名是复数,字段是单数,比如下面我们创建一张student表,代码是这样的:
package main

import (
	"fmt"
	"github.com/sirupsen/logrus"
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
)

var dB *gorm.DB

type Student struct {
	Name string
	Age  int
	Sex  string
}

func init() {
	//数据库连接信息
	username := "root"
	password := "ba161754"
	databasename := "gorm"
	localHost := "localhost"
	port := 3306

	dns := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=utf8&parseTime=True&loc=Local",
		username, password, localHost, port, databasename)
	db, err := gorm.Open(mysql.Open(dns), &gorm.Config{SkipDefaultTransaction: true})
	if err != nil {
		logrus.Error("数据库连接失败", err)
	}
	dB = db
}

func main() {
	err := dB.AutoMigrate(Student{})
	if err != nil {
		logrus.Error("数据库迁移失败", err)
	}
	fmt.Println("创建表成功")
}

创建出来的表是这样的:
在这里插入图片描述
当然我们也可以尝试修改这种命名策略:

db, err := gorm.Open(mysql.Open(dns), &gorm.Config{SkipDefaultTransaction: true,
		NamingStrategy: schema.NamingStrategy{   //
			TablePrefix:   "t_",  //表名前缀
			SingularTable: false, //禁用表名复数
			NoLowerCase:   false, //禁用小写
		}})
  • 日志显示
func initLogger() {
	var mysqlLogger logger.Interface
	mysqlLogger = logger.Default.LogMode(logger.Info) //设置日志打印级别
	mysqlLogger = logger.New(
		log.New(os.Stdout, "\r\n", log.LstdFlags), // (日志输出的目标,前缀和日志包含的内容)
		logger.Config{
			SlowThreshold:             time.Second, // 慢 SQL 阈值
			LogLevel:                  logger.Info, // 日志级别
			IgnoreRecordNotFoundError: true,        // 忽略ErrRecordNotFound(记录未找到)错误
			Colorful:                  true,        // 使用彩色打印
		},
	)
	dB.Logger = mysqlLogger
}

完整代码,仅供参考:

package main

import (
	"fmt"
	"github.com/sirupsen/logrus"
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
	"gorm.io/gorm/logger"
	"gorm.io/gorm/schema"
	"log"
	"os"
	"time"
)

var dB *gorm.DB

type Student struct {
	Name string
	Age  int
	Sex  string
}

func ConnectDB() {
	//数据库连接信息
	username := "root"
	password := "ba161754"
	databasename := "gorm"
	localHost := "localhost"
	port := 3306

	var err error
	dns := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=utf8&parseTime=True&loc=Local",
		username, password, localHost, port, databasename)
	dB, err = gorm.Open(mysql.Open(dns), &gorm.Config{SkipDefaultTransaction: true,
		NamingStrategy: schema.NamingStrategy{ //
			TablePrefix:   "t_",  //表名前缀
			SingularTable: false, //禁用表名复数
			NoLowerCase:   false, //禁用小写
		}})
	if err != nil {
		logrus.Error("数据库连接失败", err)
	}
}

func initLogger() {
	var mysqlLogger logger.Interface
	mysqlLogger = logger.Default.LogMode(logger.Info) //设置日志打印级别
	mysqlLogger = logger.New(
		log.New(os.Stdout, "\r\n", log.LstdFlags), // (日志输出的目标,前缀和日志包含的内容)
		logger.Config{
			SlowThreshold:             time.Second, // 慢 SQL 阈值
			LogLevel:                  logger.Info, // 日志级别
			IgnoreRecordNotFoundError: true,        // 忽略ErrRecordNotFound(记录未找到)错误
			Colorful:                  true,        // 使用彩色打印
		},
	)
	dB.Logger = mysqlLogger
}

func init() {
	ConnectDB()
	initLogger()
}

func main() {
	err := dB.AutoMigrate(Student{})
	if err != nil {
		logrus.Error("数据库迁移失败", err)
	}
	fmt.Println("创建表成功")
}

模型定义

模型定义示例

模型是使用普通结构体定义的。 这些结构体可以包含具有基本Go类型、指针或这些类型的别名,甚至是自定义类型(只需要实现 database/sql 包中的Scanner和Valuer接口)我们来看一下Gorm给出的user模型示例:

type User struct {
  ID           uint           // Standard field for the primary key
  Name         string         // 一个常规字符串字段
  Email        *string        // 一个指向字符串的指针, allowing for null values
  Age          uint8          // 一个未签名的8位整数
  Birthday     *time.Time     // A pointer to time.Time, can be null
  MemberNumber sql.NullString // Uses sql.NullString to handle nullable strings
  ActivatedAt  sql.NullTime   // Uses sql.NullTime for nullable time fields
  CreatedAt    time.Time      // 创建时间(由GORM自动管理)
  UpdatedAt    time.Time      // 最后一次更新时间(由GORM自动管理)
}

这里常见的uint这种类型就不做过多介绍了,这里主要是 有两个类型我们这里进行一下介绍:

  • *string(指针类型) :如果我们在这里使用string类型的话,这里我们是可以写空值的,如果我们用string类型是不允许出现空值的
  • sql.NullString sql.NullString 是 Go 语言标准库中的一个数据类型,位于 database/sql 包中。它用于表示数据库中可能为 NULL 的字符串值。它由两个字段组成:String 用于保存字符串值(如果不为 NULL),Valid 是一个布尔标志,指示字符串值是否为 NULL。在与允许字符串列包含 NULL 值的数据库一起工作时,这种类型特别有用。
type NullString struct {
	String string
	Valid  bool // Valid is true if String is not NULL
}

gorm.Model

在开始介绍gorm.Model之前,我们先讲一下几条在gorm的约定:

-主键:GORM 使用一个名为ID 的字段作为每个模型的默认主键。

  • 表名:默认情况下,GORM 将结构体名称转换为 snake_case 并为表名加上复数形式。 例如,一个 User 结构体在数据库中的表名变为 users 。

  • 列名:GORM 自动将结构体字段名称转换为 snake_case 作为数据库中的列名。

  • 时间戳字段:GORM使用字段 CreatedAt 和 UpdatedAt 来自动跟踪记录的创建和更新时间。

而在grom中存在gorm.Model这一预定义的结构体,我们可以将它直接嵌入我们所定义的结构体中,这保证了不同模型之间保持一致性并利用GORM内置的约定,gorm.model的定义如下:

type Model struct {
	ID        uint `gorm:"primarykey"` 
	CreatedAt time.Time
	UpdatedAt time.Time
	DeletedAt DeletedAt `gorm:"index"`
}

它主要包含以下字段:

  • ID :每个记录的唯一标识符(主键)。
  • CreatedAt :在创建记录时自动设置为当前时间。
  • UpdatedAt:每当记录更新时,自动更新为当前时间。
  • DeletedAt:用于软删除(将记录标记为已删除,而实际上并未从数据库中删除)。

字段标签

gorm中我们一般使用字段标签来表示字段的类型,常见的字段类型主要有以下几种:

  • type:定义字段类型
  • size:字段大小
  • column 自定义别名
  • primaryKey 将列定义为主键
  • unique 将列定义为唯一键
  • default 定义列的默认值
  • not null 不可为空
  • embedded 嵌套字段
  • embeddedPrefix 嵌套字段前缀
  • comment 注释

示例:

type StudentInfo struct {
 Email  *string `gorm:"size:32"` // 使用指针是为了存空值
 Addr   string  `gorm:"column:y_addr;size:16"`
 Gender bool    `gorm:"default:true"`
}
type Student struct {
 Name string      `gorm:"type:varchar(12);not null;comment:用户名"`
 UUID string      `gorm:"primaryKey;unique;comment:主键"`
 Info StudentInfo `gorm:"embedded;embeddedPrefix:s_"`
}
  • 11
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
使用gin与gorm框架进行后台开发是指在构建后台应用程序时,采用了gin和gorm这两个开源框架来帮助实现快速、高效且可靠的开发。 首先,gin是一个轻量级的Web框架,它基于Go语言的net/http包进行封装,并提供了更简洁的API和更快的性能。使用gin框架可以轻松地处理HTTP请求和响应,定义路由和中间件,实现参数绑定和验证,并且具备灵活的扩展性和高并发处理能力。 其次,gorm是一个开源的Go语言ORM(对象关系映射)库,它提供了一种方便的方式来操作数据库,将数据库表和Go语言的结构体进行映射,实现了数据的增删改查操作。使用gorm可以简化数据库操作的代码,提高开发效率,还支持事务处理、查询构造器等高级功能。 使用gin与gorm框架进行后台开发有以下几个优势: 1. 快速开发:gin框架提供了简洁的API和高性能,可以大大加速开发过程。结合gorm框架的ORM功能,可以方便地进行数据库操作,减少了与数据库交互的代码量,提高了开发效率。 2. 灵活扩展:gin框架支持中间件,在请求的不同阶段插入自定义的处理逻辑,可以实现身份验证、日志记录、错误处理等功能。gorm框架也支持自定义回调函数,可以在数据库操作的前后执行特定的业务逻辑,提供了灵活扩展的能力。 3. 高性能:gin框架底层采用了轻量级的路由引擎和快速的HTTP处理器,以及简洁的API设计,使得性能表现出色。同时,gorm框架通过合理的SQL语句生成和查询优化,能够保证数据库操作的效率。 综上所述,使用gin与gorm框架进行后台开发可以提供快速、高效、可靠的开发体验,同时拥有灵活的扩展性和良好的性能表现,非常适合构建中小型的后台应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

落雨便归尘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值