Gorm 结构填充问题导致异常行为
今天编程网给大家带来了《Gorm 结构填充问题导致异常行为》,其中涉及到的知识点包括等等,无论你是小白还是老手,都适合看一看哦~有好的建议也欢迎大家在评论留言,若是看完有所收获,也希望大家能多多点赞支持呀!一起加油学习~
问题内容我在 gorm 中做了一个简单的查询:
err := db.preload("users").
where("orders.created_at >= now() - interval 3 day").
find(&orders).
error
我也试过这样:
err := db.select("orders.*, users.*").
where("orders.created_at >= now() - interval 3 day and users.first_name != ''").
joins("left join users on users.customer_id = orders.customer_id").
find(&orders).
error
这应该填充一个“orders”结构,其中有一个“users users”结构。当我记录查询时,它看起来很好,当我将其复制并粘贴到 phpmyadmin 中时,它工作得很好,但在 go 中,我的结构是空的!嗯...“用户”部分是空的。订单部分填写正确。有谁知道我做错了什么?我的订单结构:
type orders struct {
customerid int
users users `gorm:"foreignkey:customer_id"`
method string
amount float64
subtotal float64
total float64
btw float64
status string
ordermailsend int
}
和我的用户结构:
type users struct {
customerid int
email string
firstname string
lastname string
}
如果我使用第一个查询并调用它(在 go 中),我将收到以下结果:
{
"CustomerId": 211197,
"Users": {
"CustomerId": 0,
"Email": "",
"FirstName": "",
"LastName": ""
},
"Method": "iDEAL",
"Amount": 10,
"Subtotal": 10,
"Total": 10,
"Btw": 0,
"Status": "paid",
"OrderMailSend": 0
}
同时出现错误:无法为模型预加载现场用户。订单
如果我只是将查询本身复制并粘贴到 phpmyadmin 控制台中并运行它,我确实会得到完整的结果,即与用户连接的一个订单。所以这意味着我认为查询本身没问题。
在数据库中,订单表 (customer_id) 有一个指向用户表 (customer_id) 的外键。
解决方案
第一件事:尝试将您的 users 键字段重命名为 customerid,这是正确的方法,而且 gorm 似乎也喜欢这样做。
此外,您的 order 结构没有主键。这可能会把事情搞砸。
有了这个,第一个查询应该可以工作。
第二个查询不会神奇地填充 users
结构,因为 find
方法仅扫描顶级实体。
joins
与您使用的自定义连接 sql 不会告诉 gorm 也将额外字段扫描到子实体中。
但由于这是一对一的关系,因此您应该能够使用 Joins preloading,它会产生与预加载查询类似的结果,但全部都在单个数据库查询中。
err := db.
Joins("Users").
Where("orders.created_at >= now() - interval 3 day AND users.first_name != ''").
Find(&orders).
Error
终于介绍完啦!小伙伴们,这篇关于《Gorm 结构填充问题导致异常行为》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~编程网公众号也会发布Golang相关知识,快来关注吧!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341