GORM: Bagaimana untuk memautkan satu kepada satu?

WBOY
Lepaskan: 2024-02-11 11:45:08
ke hadapan
801 orang telah melayarinya

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)
}
Salin selepas log masuk

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"`
}
Salin selepas log masuk

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"`
Salin selepas log masuk

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

Label berkaitan:
sumber:stackoverflow.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!