您的位置:首页 >GORM 映射下划线字段到 Go 结构体方法
发布于2026-01-29 阅读(0)
扫一扫,手机访问

GORM 默认使用蛇形转驼峰规则映射字段,当数据库列名为 `spe_Name` 等含下划线的非标准命名时,需通过 `gorm:"column:xxx"` 标签显式指定列名,否则结构体字段将无法正确读取数据。
在使用 GORM(如 v1.9.x 或早期版本)操作 MySQL 时,若数据库字段采用下划线命名(例如 spe_Name、parent_id),而 Go 结构体字段使用驼峰命名(如 SpeName、ParentId),GORM 默认会尝试将 SpeName 映射为 spe_name(全小写+下划线),而非实际存在的 spe_Name —— 这导致查询结果中 SpeName 始终为空字符串,fmt.Println(specialty.SpeName) 输出空白。
✅ 正确做法是:使用 gorm:"column:xxx" 结构体标签显式绑定字段名。修改结构体如下:
type Specialties struct {
SpeId int64 `gorm:"column:spe_Id"`
SpeName string `gorm:"column:spe_Name"`
Conditions sql.NullString `gorm:"column:conditions"`
ParentId sql.NullInt64 `gorm:"column:parent_Id"`
Hidden sql.NullInt64 `gorm:"column:hidden"`
}⚠️ 注意事项:
最后,在调用 IsFolderNameASpecialty 前,请确保 Specialties 切片已通过 db.Find(&Specialties) 等方式从数据库正确加载——否则即使标签正确,specialty.SpeName 仍为空。建议补充错误检查与日志验证,例如:
if err := db.Find(&Specialties).Error; err != nil {
log.Fatal("failed to load specialties:", err)
} 上一篇:Excel追踪修订记录方法
下一篇:PS污点修复画笔使用教程
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9