= now() - interval 3 day"). find(&orders). error " />
登录
首页 >  Golang >  Go问答

Gorm 结构填充问题导致异常行为

来源:stackoverflow

时间:2024-03-28 18:24:28 175浏览 收藏

今天golang学习网给大家带来了《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学习网公众号也会发布Golang相关知识,快来关注吧!

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