Home > Backend Development > Golang > GORM: How to link one to one?

GORM: How to link one to one?

WBOY
Release: 2024-02-11 11:45:08
forward
889 people have browsed it

GORM: How to link one to one?

GORM is a popular Go language ORM library used to simplify database operations. When using GORM for one-to-one linking, we can achieve this by defining the relationship between structures. First, we need to add a foreign key field to the structure, and then use GORM's `BelongsTo` method to associate the two structures. Next, we can use the `Preload` method to preload the related data at query time so that it can be fetched together when needed. In this way, we can easily implement one-to-one links and conveniently operate related data.

Question content

I am trying to load queue items from the database. I've created an API endpoint but am unable to get the data for the queue items to be preloaded. Instead, the entire "data" object is filled with null values.

Handler:

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)
}
Copy after login

Here's how my gorm model is set up:

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"`
}
Copy after login

I'm thinking maybe I set up the model to point to the wrong column (if any)?

Solution

Try to change this

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

The above is the detailed content of GORM: How to link one to one?. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:stackoverflow.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template