GORM 模型定义及代码示例

GORM 是一个流行的 Go 语言 ORM(对象关系映射)库,它允许开发者使用 Go 代码来操作数据库,而无需编写 SQL 语句。GORM 通过模型(Model)定义来映射数据库表的结构,使得数据库操作更加直观和方便。

模型定义基础

在 GORM 中,模型定义通常是一个结构体,每个字段都对应数据库中的一个列。GORM 通过结构体标签(Tag)来指定字段与数据库列的映射关系。以下是一些常用的 GORM 标签:

  • gorm:"type:varchar(12)":指定字段的类型为 varchar,长度为 12。
  • gorm:"size:2":指定字段的大小。
  • gorm:"column:y_addr":自定义列名。
  • gorm:"primaryKey":将列定义为主键。
  • gorm:"unique":将列定义为唯一键。
  • gorm:"default":定义列的默认值。
  • gorm:"not null":指定列不可为空。
  • gorm:"embedded":嵌套字段。
  • gorm:"embeddedPrefix:s_":嵌套字段前缀。

代码示例

根据提供的截图内容,我们可以发现一些字段标签的拼写错误和一些可能的改进点。下面是修改后的代码示例:

go 复制代码
package main

import (
	"gorm.io/driver/sqlite"
	"gorm.io/gorm"
)

// StudentInfo 嵌套结构体,用于存储学生信息
type StudentInfo struct {
	Email *string `gorm:"size:32"` // 使用指针允许为空值
	Addr  string  `gorm:"column:y_addr;size:16"`
	Gender bool    `gorm:"default:true"`
}

// Student 学生模型结构体
type Student struct {
	ID    uint   `gorm:"primaryKey;size:10"`
	Name  string `gorm:"size:16"`
	Age   int    `gorm:"size:3"`
	Email *string `gorm:"size:128"` // 允许为空的电子邮件地址
	Info  StudentInfo `gorm:"embedded;embeddedPrefix:s_"` // 嵌套 StudentInfo
}

func main() {
	// 连接数据库,这里以 SQLite 为例
	dsn := "file:./test.db?cache=shared&mode=memory&_fk=1"
	db, err := gorm.Open(sqlite.Open(dsn), &gorm.Config{})
	if err != nil {
		panic("failed to connect database")
	}

	// 使用 Debug 模式自动迁移 Student 表
	db.Debug().AutoMigrate(&Student{})
}

注意事项

  1. 指针的使用 :对于可能为空的字段,使用指针类型(如 *string)可以存储空值。
  2. 字段大小size 标签用于指定字段的大小,这有助于数据库层面的优化。
  3. 默认值 :使用 default 标签为字段指定默认值。
  4. 嵌套结构体 :使用 embedded 标签将一个结构体嵌入到另一个结构体中,同时使用 embeddedPrefix 为嵌入字段添加前缀。
相关推荐
明月看潮生1 小时前
青少年编程与数学 01-011 系统软件简介 19 SSMS 数据库管理工具
数据库·青少年编程·编程与数学
blammmp2 小时前
Redis : set集合
数据库·redis·缓存
Chase_______2 小时前
静态变量详解(static variable)
java·开发语言·jvm
翔云1234562 小时前
精准测量 MySQL 主从复制延迟—pt-heartbeat工具工作原理
数据库·mysql
厚衣服_32 小时前
第15篇:数据库中间件高可用架构设计与容灾机制实现
java·数据库·中间件
明月看潮生3 小时前
青少年编程与数学 01-011 系统软件简介 13 Microsoft SQL Server数据库
数据库·microsoft·青少年编程·系统软件
LUCIAZZZ3 小时前
项目拓展-Jol分析本地对象or缓存的内存占用
java·开发语言·jvm·数据库·缓存·springboot
寒山李白3 小时前
MySQL分库分表面试题深度解析
数据库·mysql·面试题
入眼皆含月4 小时前
docker安装mysql数据库及简单使用
数据库·mysql·docker
白露与泡影4 小时前
JVM GC 问题排查实战案例
jvm