Gorm 用 Scan() 左连接
来源:stackoverflow
时间:2024-04-18 23:00:49 166浏览 收藏
小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《Gorm 用 Scan() 左连接》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!
问题内容
我正在尝试加入 class
和 booking
上的 classes.id = bookings.class_id
并获取 displaybooking
类型的结果
type class struct { id int `json:"id"` name string `json:"name"` } type booking struct { id int `json:"id"` user string `json:"user"` members int `json:"members"` classid int `json:classid` //class class `gorm:"constraint:onupdate:cascade,ondelete:set null;"` } type displaybooking struct { id int `json:"id"` user string `json:"user"` members int `json:"members"` classid int `json:classid` classname string `json:"classname"` }
为此,我尝试了 gorm 的 scan()
和 rows()
方法
func returnallbookings(w http.responsewriter, r *http.request) { bookings := []displaybooking{} db.model(&booking{}).select("bookings.id, bookings.user, bookings.members, bookings.class_id, classes.name").joins("left join classes on bookings.class_id = classes.id").scan(&bookings) fmt.println("endpoint hit: returnallbookings") rows, err := db.table("bookings").select("bookings.id, bookings.user, bookings.members, bookings.class_id, classes.name").joins("left join classes on bookings.class_id = classes.id").rows() if err != nil { return } for rows.next() { log.println(rows) } json.newencoder(w).encode(bookings) }
scan()
在 class_name 字段中返回空值,虽然 rows()
似乎可以完成这项工作,但输出格式不是 json 编码
scan()
输出
[{"id":1,"user":"test1","members":1,"classid":2,"classname":""},{"id":2,"user":"test2","members":2,"classid":1,"classname":""}]
rows()
输出(控制台) - 粗体值是正确的,但有很多不必要的信息
my-go-app_1 | 2021/04/09 07:42:09 &{0xc00021e1b0 0x6dcfa0 0xc00026adc0 <nil> <nil> {{0 0} 0 0 0 0} false <nil> **[1 test1 1 2 business]**} my-go-app_1 | 2021/04/09 07:42:09 &{0xc00021e1b0 0x6dcfa0 0xc00026adc0 <nil> <nil> {{0 0} 0 0 0 0} false <nil> **[2 test2 2 1 first]**}
有没有办法让代码与 scan()
函数一起使用?
正确答案
你可以用scan
来做到这一点,displaybooking
的class_name
字段没有值是因为该字段默认的gorm标签名称
是class_name
,但是你要匹配的列是namezqbendcz qb,这两个不匹配。</p>
<p>您可以添加列别名来解决此问题,将
scan()
表达式更改为以下表达式:
db.Debug().Model(&Booking{}).Select("bookings.id, bookings.user, bookings.members, bookings.class_id, classes.name as class_name").Joins("left join classes on bookings.class_id = classes.id").Scan(&bookings)
以上就是《Gorm 用 Scan() 左连接》的详细内容,更多关于的资料请关注golang学习网公众号!
声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习