
gorm 中如何创建一对一关联
gorm 中的一对一关联指的是两个表之间只能有一条关联记录。例如,一个用户表和一个用户信息表,其中用户表中的每个用户只能有一个用户信息记录。要设置这种关联,我们需要在模型中定义两个模型之间的关系。
具体来说,在 user 模型中,我们需要添加一个 userinfo 字段,并指定以下信息:
- foreignkey: 该字段指定关联表中的外键字段名称。
- associationforeignkey: 该字段指定当前模型中的主键字段名称。
在 userinfo 模型中,我们需要定义一个 userid 字段,并指定 foreignkey,将它关联到 user 模型中的主键。
代码示例:
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"`
}
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)"`
}通过这种方式,在查询 user 表时,我们可以使用 preload 或 related 方法来同时获取关联的 userinfo 记录。
示例代码:
orm, _ := gorm.Open(...)
// 使用 Preload
var user User
orm.Model(User{}).Preload("UserInfo").Find(&user, 1001)
fmt.Println(user.UserInfo.Age)
// 使用 Related
var u User
var userInfo UserInfo
orm.Find(&u, 1001)
orm.Model(&u).Related(&userInfo)










