首頁 >後端開發 >Golang >自動遷移時發現結構的無效字段

自動遷移時發現結構的無效字段

WBOY
WBOY轉載
2024-02-12 17:30:06955瀏覽

自動遷移時發現結構的無效字段

問題內容

當我嘗試根據我的結構自動遷移表時,出現此錯誤,我不知道為什麼會出現此錯誤

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 無法辨識外鍵。

您需要指定在 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中文網其他相關文章!

陳述:
本文轉載於:stackoverflow.com。如有侵權,請聯絡admin@php.cn刪除