【发布时间】:2021-09-06 10:35:55
【问题描述】:
我正在尝试使用 go 创建一个简单的 REST API 作为学习项目。我在尝试使用 GORM 的 Joins 预加载功能填充 has many 关系时遇到了麻烦。
据我所知,我已经正确设置了关系,表结构在数据库中看起来不错,并且记录已插入,但以下代码会产生错误:
panic: reflect: call of reflect.Value.Field on slice Value
我在这里制作了一个显示我的问题的最小示例
package main
import (
"log"
"gorm.io/driver/postgres"
"gorm.io/gorm"
)
type Page struct {
gorm.Model
Text string
BookID uint
}
type Book struct {
gorm.Model
Pages []Page
}
func main() {
db, err := gorm.Open(postgres.Open("postgres://postgres:password@host.docker.internal:5432/postgres"), &gorm.Config{})
if err != nil {
log.Fatal(err.Error())
}
db.AutoMigrate(&Book{})
db.AutoMigrate(&Page{})
db.Create(&Book{
Pages: []Page{
{Text: "Page One"},
},
})
result := []Book{}
// errors here
db.Joins("Pages").Find(&result)
// works fine
// db.Preload("Pages").Find(&result)
}
任何关于我哪里出错的指导将不胜感激,全新的去。
【问题讨论】:
-
您提到这些表具有“多”关系。 GORM 文档提到,“加入预加载以一对一的关系工作”。听起来它可能与您当前的设计不兼容。