GORM是一個流行的Go語言ORM函式庫,用來簡化資料庫操作。在使用GORM進行一對一連結時,我們可以透過定義結構體之間的關係來實現。首先,我們需要在結構體中添加外鍵字段,然後使用GORM的`BelongsTo`方法將兩個結構體關聯起來。接下來,我們可以使用`Preload`方法在查詢時預先載入關聯數據,以便在需要時一起取得。透過這種方式,我們可以輕鬆地實現一對一鏈接,並輕鬆操作相關數據。
我正在嘗試從資料庫載入佇列項目。我已經建立了一個 API 端點,但無法取得要預先載入的佇列項目的資料。相反,整個「資料」物件充滿了空值。
處理程序:
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) }
以下是我的 gorm 模型的設定方式:
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"` }
我在想也許我設定的模型指向錯誤的列(如果有的話)?
嘗試改變這個
Data QueueItemData `json:"data" gorm:"foreignKey:QueueItemId;references:ID"`
以上是GORM:如何一對一連結?的詳細內容。更多資訊請關注PHP中文網其他相關文章!