当前位置: 首页 > news >正文

【Go】新版GORM自动字段映射规则

新版 GORM(v2 及以上)的自动字段映射遵循一套清晰的规则,主要围绕结构体字段名到数据库列名的转换,以及特殊字段的默认处理,具体规则如下:

1. 命名转换规则(核心)

GORM 会将结构体的驼峰式命名(CamelCase) 自动转换为数据库的蛇形命名(snake_case),这是最常用的映射规则。

  • 转换逻辑:在字段名的大写字母前添加下划线,并将所有字母转为小写。
  • 示例:
    • 结构体字段 StudentId → 数据库列 student_id
    • 结构体字段 ScoreValue → 数据库列 score_value
    • 结构体字段 CreatedAt → 数据库列 created_at
    • 结构体字段 ID → 数据库列 id(特殊处理:连续大写会被合并转换)

2. 特殊字段的默认映射

GORM 对一些特定名称的结构体字段有内置映射规则,无需额外配置:

  • ID:默认作为主键(primaryKey),映射到数据库列 id
  • CreatedAt:自动映射到 created_at 列,GORM 会在插入记录时自动填充当前时间。
  • UpdatedAt:自动映射到 updated_at 列,GORM 会在更新记录时自动更新为当前时间。
  • DeletedAt:如果结构体包含该字段,GORM 会启用“软删除”功能,映射到 deleted_at 列(未删除时为 NULL,删除时填充时间)。

3. 自定义映射(覆盖默认规则)

如果需要自定义列名(不遵循驼峰转蛇形),可以通过 gorm:"column:自定义列名" 标签显式指定,覆盖默认规则。
示例:

type Score struct {Id         uint64    `gorm:"primaryKey" json:"id"`  // 默认映射为 idStudentId  uint64    `gorm:"column:stu_id" json:"student_id"`  // 自定义为 stu_idSubject    string    `gorm:"column:course_name" json:"subject"`  // 自定义为 course_name// ...
}

4. 忽略字段

如果某些结构体字段不需要映射到数据库列,可以通过 gorm:"-" 标签排除:

type Score struct {// ...TempData string `gorm:"-" json:"temp_data"`  // 不会生成数据库列
}

5. 自定义映射的核心方式:配置 NamingStrategy

新版 GORM 支持自定义自动映射规则,可以通过配置 NamingStrategy 来修改默认的字段名、表名映射逻辑,满足特定的命名规范需求。

GORM 提供了 gorm.NamingStrategy 结构体,允许你自定义:

  • 表名映射规则(结构体名 → 表名)
  • 字段名映射规则(结构体字段名 → 数据库列名)
  • 联表外键命名规则
  • 索引命名规则

通过在初始化 GORM 时配置 NamingStrategy 即可生效。

示例:自定义字段名映射规则

默认规则是「驼峰转蛇形」,如果需要修改(例如改为全大写、添加前缀等),可以自定义 Column 函数:

import ("gorm.io/driver/sqlite""gorm.io/gorm""strings"
)// 自定义命名策略
namingStrategy := gorm.NamingStrategy{// 自定义字段名映射:将驼峰转为全大写(而非蛇形)Column: func(column string) string {// 示例:StudentId → STUDENTIDreturn strings.ToUpper(column)},// 可选:自定义表名映射(结构体名 → 表名)Table: func(table string) string {// 示例:在表名前加前缀 "t_"return "t_" + table},
}// 初始化 GORM 时应用命名策略
db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{NamingStrategy: namingStrategy,
})

上述配置后:

  • 结构体字段 StudentId 会映射为数据库列 STUDENTID(而非默认的 student_id
  • 结构体 Score 会映射为表 t_score(而非默认的 scores

更复杂的自定义示例(保持部分默认逻辑)

如果只想在默认规则基础上微调(例如给所有字段名加前缀),可以结合默认转换逻辑:

import ("gorm.io/gorm/schema""strings"
)namingStrategy := gorm.NamingStrategy{Column: func(column string) string {// 先使用默认的驼峰转蛇形,再添加前缀 "col_"defaultColumn := schema.NamingStrategy{}.Column(column) // 调用默认转换return "col_" + defaultColumn},
}

效果:

  • 结构体字段 ScoreValue → 默认转换为 score_value → 最终映射为 col_score_value

注意事项

  1. 自定义规则全局生效,会影响所有结构体的映射。
  2. 若个别字段需要特殊处理,可以用 gorm:"column:xxx" 标签单独指定,优先级高于全局规则。
  3. 表名默认会在结构体名基础上做「驼峰转蛇形 + 复数化」(如 Userusers),可通过 SingularTable: true 禁用复数化:
    namingStrategy := gorm.NamingStrategy{SingularTable: true, // 表名不加复数后缀(User → user)
    }
    
http://www.dtcms.com/a/318452.html

相关文章:

  • 基于深度学习的医学图像分析:使用Diffusion Models实现医学图像生成
  • word2vector细致分解(CBOW, SKIP_GRAM, 层次soft Max, 负采样)
  • 8月6日星期三今日早报简报微语报早读
  • 机器学习 朴素贝叶斯
  • 园区误报率↓79%!陌讯多模态融合算法在智慧环卫越界识别的工程实践
  • 防火墙及firewall工具详解
  • AI增强的软件测试工具
  • 解决pytorch-lightning1.6.0安装时自动下载最新的pytorch方法
  • 《深入浅出Embedding》这本书
  • 高等数学(工本)----00023 速记宝典
  • <2> Elasticsearch大规模数据迁移实战:从内存暴涨到优化策略
  • 令牌桶限流算法
  • 《动手学深度学习》读书笔记—9.3深度循环神经网络
  • 数字图像处理(冈萨雷斯)第三版:第四章——空间滤波与频域滤波(平滑与锐化)——主要内容和重点
  • SQL166 删除索引
  • 一篇认识synchronized锁
  • JAVA--流程控制语句
  • Android—服务+通知=>前台服务
  • shell基础之EOF的用法
  • 译 | 在 Python 中从头开始构建 Qwen-3 MoE
  • windos安装了python,但是cmd命令行找不到python
  • 012 网络—基础篇
  • 机器学习算法系列专栏:逻辑回归(初学者)
  • flex布局:容器的justify-content属性
  • Python训练Day35
  • Python在生物计算与医疗健康领域的应用(2025深度解析)
  • 局域网内某服务器访问其他服务器虚拟机内相关服务配置
  • 无人机遥控器舵量技术解析
  • 线上Linux服务器的优化设置、系统安全与网络安全策略
  • Android14的QS面板的加载解析