文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何用GORM获取相关数据?

2024-04-04 23:45

关注

本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《如何用GORM获取相关数据?》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~

问题内容

我想从其他表获取相关数据

我有以下模型结构

type community struct {
    id       string            `json:"id" gorm:"primarykey"`
    name     string            `json:"name"`
    category communitycategory `json:"category" gorm:"foreignkey:id"`
}
type communitycategory struct {
    id   uint32 `json:"id" gorm:"primarykey"`
    name string `json:"name"`
}

我获取数据的代码是这样的

community := community{id: 1}
database.debug().joins("communitycategory").first(&community)

有了这些,我收到以下错误 error:对表“communities”(sqlstate 42p01) 的 from 子句条目的引用无效

查看gorm的调试日志,查询是这样的

SELECT "communities"."id","communities"."name","communities"."introduction","communities"."address","communities"."postal_code","communities"."country","communities"."address1","communities"."address2","communities"."prefecture","communities"."city","communities"."lat","communities"."lng","communities"."phone","communities"."email","communities"."external_link_1","communities"."external_link_2","communities"."image_url","communities"."access","communities"."description","communities"."contact_name","communities"."contact_phone","communities"."contact_email","communities"."is_enabled","communities"."created_at","communities"."updated_at" FROM "communities" CommunityCategory WHERE "communities"."id" = '25b1eadf-1004-40b7-b9a2-325a83bcb938' ORDER BY "communities"."id" LIMIT 1

我做错了吗?哈哈


解决方案


通过按如下方式定义我的结构来修复此问题。我在 community 结构中添加了一个新字段 categoryid 并将外键更改为这个新字段

type community struct {
    id         string            `json:"id" gorm:"primarykey"`
    name       string            `json:"name"`
    categoryid uint32
    category   communitycategory `json:"category" gorm:"foreignkey:categoryid"`
}

type communitycategory struct {
    id   uint32 `json:"id" gorm:"primarykey"`
    name string `json:"name"`
}

然后在查询时,您可以像这样执行连接:

community := Community{ID: 1}
database.Model(&Community{}).Joins("Category").First(&community)

到这里,我们也就讲完了《如何用GORM获取相关数据?》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注编程网公众号,带你了解更多关于的知识点!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯