返回顶部
首页 > 资讯 > 后端开发 > GO >Gorm 结构填充问题导致异常行为
  • 858
分享到

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

2024-04-04 23:04:35 858人浏览 八月长安
摘要

今天编程网给大家带来了《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

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作