如何在 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
关联的记录。我尝试在 gorm
中的内容/方法完全做到这一点,所以我只是使用我更熟悉的简单查询。现在,我想获取与 tbl1.type_id
关联的记录。我尝试在 Raw()
之前添加 Preload()
但这似乎不起作用,因为检查我用来存储查询结果的结构数组的内容似乎没有填充 Type
之前添加 Preload()
但这似乎不起作用,因为检查我用来存储查询结果的结构数组的内容似乎没有填充 Type
。
更新:
环顾四周后,我找到了一种将上面的 Raw()
查询转换为 gorm
查询转换为 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
查询一样,但它仍然缺少一些东西,这就是获取关联表到 table1 的方法(它是方法链接上的actuator_device_infos,有点懒惰仍然清理新代码)。即使我在查询构建方法之前添加 Preload()
,它似乎也不会影响结果记录。我需要使用 Model()
进行方法链接,并且缺少它会产生错误,因为 Model()
中的解析表将用于最终查询的 FROM
部分,因此 gorm
应该有所了解我想要预加载的东西存在。我预加载的是 actuator_types
,它已经有一个 Joins()
,如上面的代码所示。
Find()
,这样 Preload()
就可以工作。最终的代码看起来就像我在问题上的代码,但我用 Find()
替换了 Scan()
。我尝试对 🎜 代码执行相同的操作,并且效果也很好。 gorm
应该提到该机制。🎜以上是如何在 Gorm 中使用 Raw() 进行 Preload() ?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

在 SQL Server 中使用 SQL 语句创建表的方法:打开 SQL Server Management Studio 并连接到数据库服务器。选择要创建表的数据库。输入 CREATE TABLE 语句,指定表名、列名、数据类型和约束。单击执行按钮创建表。

本文介绍了一种使用 SQL 语句连接三个表的详细教程,指导读者逐步了解如何有效地关联不同表中的数据。通过示例和详细的语法讲解,本文将帮助您掌握 SQL 中表的连接技术,从而能够高效地从数据库中检索关联信息。

phpMyAdmin 可用于在 PHP 项目中创建数据库。具体步骤如下:登录 phpMyAdmin,点击“新建”按钮。输入要创建的数据库的名称,注意符合 MySQL 命名规则。设置字符集,如 UTF-8,以避免乱码问题。

判断 SQL 注入的方法包括:检测可疑输入、查看原始 SQL 语句、使用检测工具、查看数据库日志和进行渗透测试。检测到注入后,采取措施修补漏洞、验证补丁、定期监控、提高开发人员意识。

检查 SQL 语句的方法有:语法检查:使用 SQL 编辑器或 IDE。逻辑检查:验证表名、列名、条件和数据类型。性能检查:使用 EXPLAIN 或 ANALYZE,检查索引并优化查询。其他检查:检查变量、权限和测试查询。

PostgreSQL 添加列的方法为使用 ALTER TABLE 命令并考虑以下细节:数据类型:选择适合新列存储数据的类型,如 INT 或 VARCHAR。默认值:通过 DEFAULT 关键字指定新列的默认值,避免值为 NULL。约束条件:根据需要添加 NOT NULL、UNIQUE 或 CHECK 约束条件。并发操作:使用事务或其他并发控制机制处理添加列时的锁冲突。

phpMyAdmin不仅仅是数据库管理工具,它能让你深入理解MySQL,提升编程技巧。核心功能包括CRUD和SQL查询执行,理解SQL语句的原理至关重要。高级技巧包括导出/导入数据和权限管理,需要深入的安全理解。潜在问题包括SQL注入,解决方案是参数化查询和备份。性能优化涉及SQL语句优化和索引使用。最佳实践强调代码规范、安全实践和定期备份。
