今天编程网给大家带来了《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相关知识,快来关注吧!
--结束END--
本文标题: Gorm 结构填充问题导致异常行为
本文链接: https://lsjlt.com/news/595799.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-04-05
2024-04-05
2024-04-05
2024-04-04
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-04
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0