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 为嵌入字段添加前缀。
相关推荐
张声录12 分钟前
【ETCD】【实操篇(三)】【ETCDCTL】如何向集群中写入数据
数据库·chrome·etcd
无为之士8 分钟前
Linux自动备份Mysql数据库
linux·数据库·mysql
小汤猿人类22 分钟前
open Feign 连接池(性能提升)
数据库
阳冬园43 分钟前
mysql数据库 主从同步
数据库·主从同步
Mr.132 小时前
数据库的三范式是什么?
数据库
Cachel wood2 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
Python之栈2 小时前
【无标题】
数据库·python·mysql
风_流沙2 小时前
java 对ElasticSearch数据库操作封装工具类(对你是否适用嘞)
java·数据库·elasticsearch
亽仒凣凣2 小时前
Windows安装Redis图文教程
数据库·windows·redis
亦世凡华、3 小时前
MySQL--》如何在MySQL中打造高效优化索引
数据库·经验分享·mysql·索引·性能分析