戈姆属于不返回关系

我有这些模型


    type Message struct {

    gorm.Model

    UserID  uint `json:"userId"`

    User    userModels.User

    Content string `json:"content"`

}


type Receiver struct {

    gorm.Model

    UserID    uint `json:"userId"`

    User      userModels.User

    FirstName string `json:"firstName"`

    LastName  string `json:"lastName"`

    Email     string `json:"email"`

    Address   string `json:"address"`

    Phone     string `json:"phone"`

}


type Delivery struct {

    gorm.Model

    Message      Message   `json:"message"`

    MessageID    uint      `json:"messageId"`

    Receiver     Receiver  `json:"Receiver"`

    ReceiverID   uint      `json:"receiverId"`

    DeliveryDate time.Time `json:"deliveryDate"`

    Sent         bool      `json:"sent"`

}

我在数据库中插入了一些具有特定消息ID和接收器ID的传递。当我查询某个传递时,我希望获得 ID 为 MessageID 的相关消息,以及 id 为接收器 ID 的接收器。但是我得到的是一个同时包含空消息和接收方对象的传递。


这就是我得到的:


 {

            "ID": 2,

            "CreatedAt": "2021-08-26T04:44:33.366628+04:30",

            "UpdatedAt": "2021-08-26T04:44:33.366628+04:30",

            "DeletedAt": null,

            "message": {

                "ID": 0,

                "CreatedAt": "0001-01-01T00:00:00Z",

                "UpdatedAt": "0001-01-01T00:00:00Z",

                "DeletedAt": null,

                "userId": 0,

                "User": {

                    "ID": 0,

                    "CreatedAt": "0001-01-01T00:00:00Z",

                    "UpdatedAt": "0001-01-01T00:00:00Z",

                    "DeletedAt": null,

                    "firstName": "",

                    "lastName": "",

                    "email": "",

                    "password": "",

                    "country": "",

                    "dateOfBirth": "0001-01-01T00:00:00Z",

                    "rank": "",

                    "gender": "",

                    "plan": ""

                },

                "content": ""

            },

      

虽然我希望它返回消息,其中包含我指定的消息Id以及接收器


慕森王
浏览 62回答 1
1回答

HUX布斯

When I query that certain Delivery你好?如果使用预加载 db.Preload("Message").Preload("Receiver").First(&d3)您将获得接收器和消息的指示,例如如果不使用预加载,您将获得包含空消息和接收方对象的传递。如果只需要消息 Id 和接收方 ID,则应将 更改为 和Message      Message Message      *Message Receiver     ReceiverReceiver     *Receiver如果您使用预加载 ->与上述相同如果不使用预加载 ->则接收方和消息将为零以下是所有测试代码和调试信息:type User3 struct {    gorm.Model    Name      string}type Message struct {    gorm.Model    UserID  uint `json:"userId"`    User    *User3    Content string `json:"content"`}type Receiver struct {    gorm.Model    UserID    uint `json:"userId"`    User      *User3    FirstName string `json:"firstName"`    LastName  string `json:"lastName"`    Email     string `json:"email"`    Address   string `json:"address"`    Phone     string `json:"phone"`}type Delivery struct {    gorm.Model    Message      *Message   `json:"message"`    MessageID    uint      `json:"messageId"`    Receiver     *Receiver  `json:"Receiver"`    ReceiverID   uint      `json:"receiverId"`    DeliveryDate time.Time `json:"deliveryDate"`    Sent         bool      `json:"sent"`}func main() {    db := config.CreateMysql()    db.AutoMigrate(Delivery{})    d := Delivery{Message: &Message{User: &User3{Name: "a"}, Content: "hello b~"}, Receiver: &Receiver{User: &User3{Name: "b"}}, DeliveryDate: time.Now(), Sent: false}    db.Create(&d)    d2 := Delivery{}    db.First(&d2)    fmt.Printf("%v\n", d2)    d3 := Delivery{}    db.Preload("Message").Preload("Receiver").First(&d3)    fmt.Printf("%v\n", d3)}在此处输入图像描述ps:以上用户为零,如果要预加载嵌套关联,请使用以下方法:https://gorm.io/docs/preload.html.Preload("Message.User")
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go