我试图与gorm ORM定义一对多关系。我已经读了一遍又一遍的所有文档。无法找到一种方法。
func GetUser1(c *gin.Context) {
var user models.User
var activities models.UserActivity
query := DB.Debug().Find(&user, 1).Model(&user).Related(&activities).Error
if query != nil {
panic(query)
}
c.JSON(200, &user)
}
我的模特是..
type User struct {
Id int64
Username string
Password string `json:"-"`
Email string `json:",omitempty"`
UserActivities []UserActivity
}
type UserActivity struct {
Id int64
UserId int64 `json:"-"`
ActorId int64
CreatedAt time.Time
}
调试结果是
[2015-11-21 22:21:54] [3.17ms] SELECT * FROM `users` WHERE (`id` = '1')
[2015-11-21 22:21:54] [1.39ms] SELECT * FROM `user_activities` WHERE (`user_id` = '1')
但我得到空结果
{
"Id": 1,
"Username": "test1",
"Email": "[email protected]",
"UserActivities": null
}
所有主键和索引都正确。到目前为止,我还尝试过
gorm:"primary_key"
中的puttin sql:"index"
和UserActivities
,但没有运气。但是,如果我用
UserActivities []UserActivity
替换UserActivities UserActivity
,那么我只会得到一行似乎正确的行,但是为什么UserActivities []UserActivity
没有给出结果 最佳答案
使用内置模型gorm.Model中的gorm,这样您就不会弄乱“ID”常量