GORM是一個(gè)流行的Go語言O(shè)RM庫,用于簡化數(shù)據(jù)庫操作。在使用GORM進(jìn)行一對(duì)一鏈接時(shí),我們可以通過定義結(jié)構(gòu)體之間的關(guān)系來實(shí)現(xiàn)。首先,我們需要在結(jié)構(gòu)體中添加外鍵字段,然后使用GORM的`BelongsTo`方法將兩個(gè)結(jié)構(gòu)體關(guān)聯(lián)起來。接下來,我們可以使用`Preload`方法在查詢時(shí)預(yù)加載關(guān)聯(lián)數(shù)據(jù),以便在需要時(shí)一起獲取。通過這種方式,我們可以輕松地實(shí)現(xiàn)一對(duì)一鏈接,并方便地操作相關(guān)數(shù)據(jù)。
問題內(nèi)容
我正在嘗試從數(shù)據(jù)庫加載隊(duì)列項(xiàng)目。我已經(jīng)創(chuàng)建了一個(gè) API 端點(diǎn),但無法獲取要預(yù)加載的隊(duì)列項(xiàng)目的數(shù)據(jù)。相反,整個(gè)“數(shù)據(jù)”對(duì)象充滿了空值。
處理程序:
func QueueItemHandler(w http.ResponseWriter, r *http.Request) { var queueItems QueueItem var builder = database.Model(QueueItem{}) var queryError = builder. Preload("Status"). Preload("Data"). Find(&queueItems). Error w.Header().Set("Content-Type", "application/json") json.NewEncoder(w).Encode(queueItems) }
登錄后復(fù)制
以下是我的 gorm 模型的設(shè)置方式:
type QueueItemStatus struct { ID int64 `json:"id" gorm:"primary_key"` Name string `json:"name"` Description string `json:"description"` } type QueueItemData struct { ID int64 `json:"id" gorm:"primary_key"` QueueItemId int64 `json:"queue_item_id"` ScreenshotUrl string `json:"screenshot_url"` } type QueueItem struct { ID int64 `json:"id" gorm:"primary_key"` SourceUrl string `json:"source_url"` OriginId int64 `json:"origin_id"` StatusId int64 `json:"status_id"` Status QueueItemStatus `json:"status"` Data QueueItemData `json:"data" gorm:"foreignKey:id,references:queue_item_id"` CreatedAt time.Time `json:"created_at"` }
登錄后復(fù)制
我在想也許我設(shè)置的模型指向錯(cuò)誤的列(如果有的話)?
解決方法
嘗試改變這個(gè)
Data QueueItemData `json:"data" gorm:"foreignKey:QueueItemId;references:ID"`
登錄后復(fù)制