如何在 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.nameFROM table1 tbl1JOIN table2 tbl2 ON tbl1.some_tbl2_id = tbl2.idJOIN table3 tbl3 ON tbl3.edge_device_info_id = tbl2.idJOIN table4 tbl4 ON tbl4.id = tbl3.account_idLEFT JOIN table5 tbl5 ON tbl5.tbl1_id = tbl1.idWHERE 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 应该提到该机制。

以上就是如何在 Gorm 中使用 Raw() 进行 Preload() ?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2483454.html

(0)
上一篇 2025年3月4日 21:18:58
下一篇 2025年1月4日 01:45:58

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 通过 AWS SES v2 在 Go 中发送带有附件的原始电子邮件

    php小编小新为您带来了一篇关于在Go中使用AWS SES v2发送带附件的原始电子邮件的文章。AWS SES v2是一种灵活可靠的电子邮件服务,而Go是一种强大的编程语言,两者的结合能帮助您轻松发送带有附件的原始电子邮件。本文将详细介绍如…

    2025年3月4日
    200
  • 提高Go项目开发效率:推荐的实用开发工具介绍

    高效开发Go语言项目:值得尝试的实用开发工具介绍 Go语言作为一种高效、简洁的编程语言,受到越来越多开发者的青睐。然而,在实际项目开发中,有时候我们可能会遇到一些繁琐的工作,这就需要借助一些实用的开发工具来提高开发效率。本文将介绍几款值得尝…

    2025年3月4日
    200
  • 深入了解Go语言库:五个不可错过的利器

    标题:深入了解Go语言库:五个不可错过的利器 Go语言作为一门快速、高效的编程语言,其标准库和第三方库为开发者提供了丰富的工具和资源。本文将介绍五个在Go语言开发中不可错过的利器,让我们一起深入了解这些强大的库,并附上具体的代码示例。 1.…

    2025年3月4日
    200
  • Go语言IDE开发工具盘点:选择适合自己的最佳方案

    Go语言是一种高效、简洁的编程语言,越来越受到开发者的青睐。针对Go语言的开发工具也是开发者们必不可少的利器之一。本文将盘点一些常用的Go语言IDE开发工具,分析各自的特点和适用场景,帮助开发者选择最适合自己的开发工具。 一、Visual …

    2025年3月4日
    200
  • Go语言库全面解析:五款提升开发效率的神器

    Go语言作为一种快速、高效的编程语言,越来越受到开发人员的青睐。在Go语言的生态系统中,有许多优秀的库(library)可以帮助开发人员提高工作效率,简化开发过程。本文将对五款提升开发效率的神器进行全面解析,为读者呈现这些优秀的库的特点、用…

    2025年3月4日
    200
  • 提升编程效率:Golang工具助力方案

    Golang是一种受欢迎的开发语言,它具有高效的并发能力和简洁的语法,深受开发者的喜爱。然而,在实际编程过程中,我们常常会遇到一些重复的任务或者困难的问题,这时就需要借助一些优秀的辅助工具来提高开发效率和质量。本文将介绍一些常用的Golan…

    2025年3月4日
    200
  • Go语言编程:提高效率的简洁实践

    Golang简洁之道:高效编程实践 作为一种简洁高效的编程语言,Golang(又称Go语言)在近年来逐渐受到程序员们的关注和喜爱。其简洁的语法、快速的编译速度以及强大的并发特性,使得Golang成为许多开发者们的首选之一。然而,要想在Gol…

    2025年3月4日
    200
  • 使用Golang编写高性能的数据库存储过程

    标题:利用Golang创建高效的存储过程 在软件开发过程中,存储过程是一种保存在数据库中的一组SQL语句集合,可以被客户端程序随时调用执行。存储过程可以提高数据库访问效率、减少网络传输开销,并且可以实现业务逻辑的封装,保证数据操作的一致性和…

    2025年3月4日
    200
  • 推荐五款Go语言常用框架,让您快速入门

    Title: 快速上手:五款Go语言常用框架推荐 近年来,随着Go语言的流行,越来越多的开发者选择采用Go进行项目开发。Go语言以其高效、简洁和性能优越等特点受到了广泛关注。在Go语言开发中,选择适合的框架能够提高开发效率和代码质量。本文将…

    2025年3月4日
    200
  • 编写易维护的Golang存储过程

    如何在Golang中编写可维护的存储过程 在Golang中,想要编写可维护的存储过程,首先需要了解存储过程的概念以及如何在Golang中实现。存储过程是一种存储在数据库中的包含一系列SQL语句的重复使用的代码块。通过存储过程,可以简化代码、…

    2025年3月4日
    200

发表回复

登录后才能评论