首頁 > 後端開發 > Golang > 主體

GORM:如何一對一連結?

WBOY
發布: 2024-02-11 11:45:08
轉載
803 人瀏覽過

GORM:如何一對一連結?

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中文網其他相關文章!

相關標籤:
來源:stackoverflow.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!