Gorm如何定义一对一

发布于 2022-09-12 03:58:20 字数 528 浏览 32 评论 0

有2张表,User表和User_info表,结构如下

User表 :

字段名称
id1001
usernamewang
status1

User_info表 :

字段名称
id1
user_id1001
age40
openidxxxxx

我想知道如何设置结构体,可以让我只需要查询user表,就可以一同查询出关联的user_info表。 看文档半天没看懂。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

信愁 2022-09-19 03:58:20

大概就是这个样子,主要要在 Model 里定义好两个 model 的关系,然后查询 User 的时候 Prelod 下 UserInfo 就可以了..或者 拿到一个已有的 model 对象去 Related 他的关联对象;区别就是 related是取值到一个指定结构里,Preload 是取值到原有结构里的对象上

type User struct {
    Uid  uint64  `gorm:"column:uid;primary_key"` 
    Username string `gorm:"column:username;type:varchar(50);"
    Status bool `gorm:"column:status;type:int(10)"`
    UserInfo UserInfo  `gorm:"ForeignKey:Uid;AssociationForeignKey:UserId"`
}
func(User)TableName() string {
    return "user"
}

type UserInfo struct {
    Id  uint64  `gorm:"column:id;primary_key"` 
    UserId uint64 `gorm:"column:user_id;type:bigint(20)"`
    Age  uint64 `gorm:"column:age;type:int(10)"`
    Openid string `gorm:"column:openid;type:varchar(250)"`
}
func(UserInfo)TableName()string{
    return "user_info"
}

orm,_ := gorm.Open(.....,.....)
//使用一,preload
var user User
orm.Model(User{}).Preload("UserInfo").Find(&user,1001)
fmt.Println(user.UserInfo.Age)

//使用二 relate
var u User
var userInfo UserInfo
orm.Find(&u,1001)
orm.Model(&u).Related(&userInfo)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文