最新公告
  • 欢迎您光临码农资源网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!加入我们
  • 如何在 Gorm 中使用 Raw() 进行 Preload() ?

    如何在 gorm 中使用 raw() 进行 preload() ?

    php小编鱼仔将为您介绍如何在 Gorm 中使用 Raw() 进行 Preload()。Gorm是一个强大的Go语言ORM库,提供了许多便捷的方法来进行数据库操作。在某些情况下,我们可能需要使用原生的SQL语句进行查询,同时还想使用Preload()方法来预加载相关的数据。通过使用Raw()方法,我们可以在Gorm中结合Preload()来实现这一需求。接下来,我们将详细讲解具体的操作步骤,帮助您更好地理解和应用这个技巧。

    问题内容

    之前在我的项目中,我需要做一些复杂的查询,所以我使用了 Raw()。查询如下所示:

    SELECT tbl1.id, tbl1.some_name, tbl5.some_status, tbl1.some_tbl2_id, tbl1.type_id, tbl1.created_at, tbl5.name
    FROM table1 tbl1
    JOIN table2 tbl2 ON tbl1.some_tbl2_id = tbl2.id
    JOIN table3 tbl3 ON tbl3.edge_device_info_id = tbl2.id
    JOIN table4 tbl4 ON tbl4.id = tbl3.account_id
    LEFT JOIN table5 tbl5 ON tbl5.tbl1_id = tbl1.id
    WHERE tbl5.tbl1_id IS NULL OR tbl5.updated_at = (
        SELECT MAX(updated_at)
        FROM table5
        WHERE tbl1_id = tbl1.id
    )
    ORDER BY tbl1.created_at ASC;

    我不太确定我是否可以使用 gorm 中的内容/方法完全做到这一点,所以我只是使用我更熟悉的简单查询。现在,我想获取与 tbl1.type_id 关联的记录。我尝试在 Raw() 之前添加 Preload() 但这似乎不起作用,因为检查我用来存储查询结果的结构数组的内容似乎没有填充 Type

    更新:

    环顾四周后,我找到了一种将上面的 Raw() 查询转换为 gorm 的方法链接的方法。它看起来像这样:

    Model(models.ActuatorDeviceInfo{}).Preload("ActuatorDeviceInfo.Type").
    Select("actuator_device_infos.*, actuator_device_infos.id, at.*").
    Joins("JOIN edge_device_infos edi ON actuator_device_infos.parent_edge_device_id = edi.id").
    Joins("JOIN user_owned_edge_devices ae ON ae.edge_device_info_id = edi.id").
    Joins("JOIN accounts acc ON acc.id = ae.account_id").
    Joins("JOIN actuator_types at ON at.id = actuator_device_infos.type_id").
    Joins("LEFT JOIN actuator_updates au ON au.actuator_device_info_id = actuator_device_infos.id").
    Where("au.actuator_device_info_id IS NULL OR au.updated_at = (?)",
        helpers.GetDB().Model(&models.ActuatorUpdate{}).Select("MAX(updated_at)").
        Where("au.actuator_device_info_id = actuator_device_infos.id")).
    Order("actuator_device_infos.created_at DESC").
    Scan(&actuator_device_infos)

    它的工作方式就像之前的 Raw() 查询一样,但它仍然缺少一些东西,这就是获取关联表到 table1 的方法(它是方法链接上的actuator_device_infos,有点懒惰仍然清理新代码)。即使我在查询构建方法之前添加 Preload() ,它似乎也不会影响结果记录。我需要使用 Model() 进行方法链接,并且缺少它会产生错误,因为 Model() 中的解析表将用于最终查询的 FROM 部分,因此 gorm 应该有所了解我想要预加载的东西存在。我预加载的是 actuator_types,它已经有一个 Joins(),如上面的代码所示。

    解决方法

    感谢@Trock的评论,我终于找到了最后一块拼图。看来我只需要在方法链的末尾使用 Find() ,这样 Preload() 就可以工作。最终的代码看起来就像我在问题上的代码,但我用 Find() 替换了 Scan() 。我尝试对 Raw() 代码执行相同的操作,并且效果也很好。 gorm 应该提到该机制。

    想要了解更多内容,请持续关注码农资源网,一起探索发现编程世界的无限可能!
    本站部分资源来源于网络,仅限用于学习和研究目的,请勿用于其他用途。
    如有侵权请发送邮件至1943759704@qq.com删除

    码农资源网 » 如何在 Gorm 中使用 Raw() 进行 Preload() ?
    • 7会员总数(位)
    • 25846资源总数(个)
    • 0本周发布(个)
    • 0 今日发布(个)
    • 292稳定运行(天)

    提供最优质的资源集合

    立即查看 了解详情