Rumah  >  Artikel  >  pembangunan bahagian belakang  >  GORM: Bagaimana untuk memautkan satu kepada satu?

GORM: Bagaimana untuk memautkan satu kepada satu?

WBOY
WBOYke hadapan
2024-02-11 11:45:08850semak imbas

GORM: Bagaimana untuk memautkan satu kepada satu?

GORM ialah perpustakaan ORM bahasa Go yang popular digunakan untuk memudahkan operasi pangkalan data. Apabila menggunakan GORM untuk pautan satu-ke-satu, kita boleh mencapai ini dengan menentukan hubungan antara struktur. Mula-mula, kita perlu menambah medan kunci asing pada struktur, dan kemudian menggunakan kaedah `BelongsTo` GORM untuk mengaitkan kedua-dua struktur. Seterusnya, kita boleh menggunakan kaedah `Pramuat` untuk pramuat data berkaitan pada masa pertanyaan supaya ia boleh diambil bersama apabila diperlukan. Dengan cara ini, kami boleh melaksanakan pautan satu dengan satu dengan mudah dan mengendalikan data berkaitan dengan mudah.

Kandungan soalan

Saya cuba memuatkan item baris gilir daripada pangkalan data. Saya telah mencipta titik akhir API tetapi tidak dapat mendapatkan data untuk item baris gilir dimuatkan. Sebaliknya, keseluruhan objek "data" diisi dengan nilai nol.

Pengendali:

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)
}

Begini cara model gorm saya disediakan:

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"`
}

Saya terfikir mungkin saya menetapkan model untuk menunjuk ke lajur yang salah (jika ada)?

Penyelesaian

Cuba ubah ini

Data       QueueItemData    `json:"data" gorm:"foreignKey:QueueItemId;references:ID"`

Atas ialah kandungan terperinci GORM: Bagaimana untuk memautkan satu kepada satu?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam