
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"`
}⚠️ 注意事项:
- column: 标签中的值必须与 MySQL 实际列名完全一致(包括大小写和下划线位置),MySQL 在多数配置下对列名大小写不敏感,但显式声明可避免歧义;
- 若使用 GORM v2(github.com/go-gorm/gorm),语法保持兼容,仍支持 column:;但推荐同时添加主键/非空等约束(如 gorm:"primaryKey")以提升可维护性;
- 避免依赖 GORM 的自动转换逻辑处理非常规命名,显式声明是更可靠、更易调试的方式;
- 若表中存在大量此类字段,可考虑统一改用标准蛇形命名(如 spe_name → spe_name),使 GORM 默认映射生效,减少冗余标签。
最后,在调用 IsFolderNameASpecialty 前,请确保 Specialties 切片已通过 db.Find(&Specialties) 等方式从数据库正确加载——否则即使标签正确,specialty.SpeName 仍为空。建议补充错误检查与日志验证,例如:
if err := db.Find(&Specialties).Error; err != nil {
log.Fatal("failed to load specialties:", err)
}










