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)
}