我正在使用 gqlgen 和 gorm 作为 orm 学习 golang,我正在创建一个使用 2 个模型用户和消息的应用程序,其中用户有一个消息列表,并且消息有发送者和接收者。我使它们如下所示type User struct { ID string `json:"id" gorm:"primary_key;type:uuid;default:uuid_generate_v4()"` Username string `json:"username"` Email string `json:"email"` FirstName string `json:"firstName"` LastName string `json:"lastName"` Messages []*Message `json:"messages"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` DeletedAt *time.Time `json:"deleted_at" sql:"index"`}type Message struct { ID string `json:"id" gorm:"primary_key;type:serial"` Title string `json:"title"` Body string `json:"body"` DueDate time.Time `json:"dueDate"` IsViewed bool `json:"isViewed" gorm:"default:false"` SenderID string `json:"senderId" gorm:"type:uuid"` Sender *User `json:"sender" gorm:"foreignkey:SenderID"` RecipientID string `json:"recipientId" gorm:"type:uuid"` Recipient *User `json:"recipient" gorm:"foreignkey:RecipientID"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` DeletedAt *time.Time `json:"deleted_at" sql:"index"`}当我使用 Preload 检索消息数据时var messages []*models.Messageerr := db. Preload("Sender"). Preload("Recipient"). Find(&messages).Errorif err != nil { return nil, err}return messages, err它工作得很好,但我的问题是在尝试检索预加载消息的用户时。var users []*models.Usererr := db. Preload("Messages"). Find(&users).Errorif err != nil { return nil, err}return users, err这给了我以下错误can't preload field Messages for models.User我知道如果有更好的组织方式,我可能会错误地设计我的架构,我将非常感激,在此先感谢。
1 回答
萧十郎
TA贡献1815条经验 获得超13个赞
我认为您应该将消息分隔User到SentMessages和ReceivedMessages中。然后你可以像这样指定外键User:
SentMessages []*Message `gorm:"foreignkey:SenderID" json:"sentMessages"`
ReceivedMessages []*Message `gorm:"foreignkey:RecipientID" json:"receivedMessages"`
然后将其用作以下内容:
var users []*models.User
err := db.
Preload("SentMessages").
Preload("ReceivedMessages").
Find(&users).Error
if err != nil {
return nil, err
}
return users, err
应该可以按您的意愿工作
- 1 回答
- 0 关注
- 516 浏览
添加回答
举报
0/150
提交
取消