
当我尝试根据我的结构自动迁移表时,出现此错误,我不知道为什么会出现此错误
failed to parse value &models.model{id:0x0, createdat:time.date(1,
time.january, 1, 0, 0, 0, 0, time.utc), updatedat:time.date(1,
time.january, 1, 0, 0, 0, 0, time.utc), deletedat:,
dogdata:[]models.dogdata(nil)}, got error invalid field found for
struct github.com/dog-page/models.model's field dogdata: define a
valid foreign key for relations or implement the valuer/scanner
interface
我是 golang 语言和 gorm 的新手,特别是在为原始 json 数据创建结构时,这里是我使用 gorm 的结构的意图:
type Model struct {
ID uint `gorm:"primarykey:id" json:"id:_id"`
CreatedAt time.Time `gorm:"column:created_at" json:"created_at"`
UpdatedAt time.Time `gorm:"column:updated_at" json:"updated_at"`
DeletedAt *time.Time `gorm:"column:deleted_at" json:"deleted_at"`
DogData []DogData
}
type DogData struct {
DogDataID uint
Name string `json:"name"`
Life_Span string `json:"life_span"`
Temperaments string `json:"temperament"`
Weight datatypes.JSON `json:"weight"`
Height datatypes.JSON `json:"height"`
Image datatypes.JSON `json:"image"`
}
type Weight struct {
Imperial string `json:"imperial"`
Metric string `json:"metric"`
}
type Height struct {
Imperial string `json:"imperial"`
Metric string `json:"metric"`
}
type Image struct {
URL string `json:"url"`
}
模型的字段 dogdata:为关系定义有效的外键
模型与 dogdata 具有一对多关系, gorm 无法识别外键。
传统驾校预约方式步骤繁琐,效率低下,随着移动互联网科技和5G的革新,驾校考试领域迫切需要更加简洁、高效的预约方式,便捷人们的生活。因此设计基于微信小程序的驾校预约系统,改进传统驾校预约方式,实现高效的驾校学校预约。 采用腾讯提供的小程序云开发解决方案,无须服务器和域名。驾校预约管理:开始/截止时间/人数均可灵活设置,可以自定义客户预约填写的数据项驾校预约凭证:支持线下到场后校验签到/核销/二维码自
0
您需要指定在 dogdata 中存储 model.id 的列(gorm 默认查找 modelid),
type model struct {
id uint `gorm:"primarykey:id" json:"id:_id"`
...
dogdata []dogdata
}
type dogdata struct {
modelid uint
dogdataid uint
...
}
//create table `dog_data` (`model_id` integer,`dog_data_id` integer,`name` text,`life_span` text,`temperaments` text,constraint `fk_models_dog_data` foreign key (`model_id`) references `models`(`id`))
或者如果您想使用另一列而不是使用foreignkey标记指定该列
type model struct {
id uint `gorm:"primarykey:id" json:"id:_id"`
...
dogdata []dogdata `gorm:"foreignkey:dogdataid"`
}
type dogdata struct {
dogdataid uint
...
}
//create table `dog_data` (`model_id` integer,`dog_data_id` integer,`name` text,`life_span` text,`temperaments` text,constraint `fk_models_dog_data` foreign key (`dog_data_id`) references `models`(`id`))
不确定用例,但我认为 dogdata 可以简化为,完全删除 model 结构,因为它与 gorm.model 相同
type DogData struct {
gorm.Model
Name string `json:"name"`
...
}
以上就是自动迁移时发现结构的无效字段的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号