
问题内容
当我尝试根据我的结构自动迁移表时,出现此错误,我不知道为什么会出现此错误
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 无法识别外键。
高端网络建设公司设计类网站模板 IT互联网移动建站类网站源码(带手机版数据同步)本套模板采用现在非常流行的全屏自适应布局设计,且栏目列表以简洁,非常时尚大气。后台支持可视拖拽编辑。 模板特点:1、手工书写DIV+CSS、代码精简无冗余。2、自适应结构,全球先进技术,高端视觉体验。3、SEO框架布局,栏目及文章页均可独立设置标题/关键词/描述。4、后台直接修改联系方式、传真、邮箱、地址等,修改更加方
您需要指定在 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"`
...
}









