douyiyi5284 2019-07-01 08:43
浏览 25
已采纳

多人一对一返回空

I want to use gorm the use a many to one relationship in my project. My structs are like this:

type Book struct {
    ID          uint
    Title       string
    Subtitle    string
    Chapters    []Chapter `gorm:"foreignkey:BookID;association_foreignkey:ID"`

} }

// TableName is book
func (Book) TableName() string {
    return "book"
}

// Chapter of books
type Chapter struct {
    ID      uint
    BookID  string
    Chapter string
}

What I want is to get chapters of a book by using this command:book.chapters. I use the following codes to get books and chapters:

var book models.Book
    db.First(&book, "id = ?", 4)
    fmt.Println(book.ID, book.Chapters) // returns []

when I query chapters with book_id = 4, I get 11 results:

   var chapters []models.Chapter
   db.Find(&chapters, "book_id = ? ", 4)
   fmt.Println("len(chapters) = ", len(chapters)) // len(chapters) =11

and when I set db.LogMode(true) and see what happens in the code I see that querying book only queries the books not joining that with chapters:

SELECT * FROM "book" WHERE (id = 4) ORDER BY "book"."id" ASC LIMIT 1

Is there something that I missed from the documentation? how should I make the book struct the get non-empty book.chapters.

  • 写回答

1条回答 默认 最新

  • duanlie7962 2019-07-01 09:20
    关注

    Your problem is probably in Preloading: http://gorm.io/docs/preload.html#Preload

    Try the following:

    var book models.Book
    db.Preload("Chapters").First(&book, "id = ?", 4)
    fmt.Println(book.ID, book.Chapters)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。