登录
首页 >  Golang >  Go问答

如何仅根据 GORM 中祖父表的键选择子表(该键仅存在于其直接父表中)

来源:stackoverflow

时间:2024-04-18 21:48:36 451浏览 收藏

目前golang学习网上已经有很多关于Golang的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《如何仅根据 GORM 中祖父表的键选择子表(该键仅存在于其直接父表中)》,也希望能帮助到大家,如果阅读完后真的对你学习Golang有帮助,欢迎动动手指,评论留言并分享~

问题内容

这张图片中有 3 个桌子。

一个表“user”可以有多个“catalog_habit”,而“catalog_habit”可以有多个“habit”。

我正在尝试找到一种使用 Gorm Preload 使 API 显示“用户”表的特定“id”主键中的所有“习惯”相关表的方法。

它可以显示3个表的所有信息,但我只想获取前端人员的“习惯”信息:(

请大家帮帮忙,谢谢!


正确答案


这取决于您想要如何加载和显示此数据。

仅加载指定用户的所有习惯

var habits []habit
err := db.joins("join catalog_habit ch on ch.id = habit.catalog_id").
          joins("join user u on u.id = ch.user_id").
          where("u.id = ?", userid).find(&habits).error

加载用户及其目录习惯和习惯

为此,您的结构应该是这样的:

type user struct {
  //other fields
  cataloghabits []cataloghabit
}

type cataloghabit struct {
  // other fields
  userid int64
  habits []habit
}

type habit struct {
  //other fields
  cataloghabitid int64
}

然后,您可以编写一个查询来加载用户数据,以及他的目录习惯和习惯:

var user User
err := db.Preload("CatalogHabits.Habits").First(&user, userID).Error

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何仅根据 GORM 中祖父表的键选择子表(该键仅存在于其直接父表中)》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>