如何在 Gorm 中使用 Raw() 进行 Preload() ?

问题描述 投票:0回答:1

之前在我的项目中,我需要做一些复杂的查询,所以我使用了

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
关联的记录。我尝试在
Preload()
之前添加
Raw()
但这似乎不起作用,因为检查我用来存储查询结果的结构数组的内容似乎没有填充
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 的方法(它是方法链接上的 actor_device_infos,有点懒,仍然清理新代码)。即使我在查询构建方法之前添加
Preload()
,它似乎也不会影响结果记录。我需要使用
Model()
进行方法链接,并且缺少它会产生错误,因为来自
Model()
的解析表将用于最终查询的
FROM
部分,因此
gorm
应该有点意识到我想要预加载的东西存在。我预加载的东西是
actuator_types
,并且它已经有一个
Joins()
,正如您在上面的代码中看到的那样。

go go-gorm
1个回答
0
投票

感谢@Trock的评论,我终于找到了最后一块拼图。看来我只需要在方法链的末尾使用

Find()
,这样
Preload()
就可以工作了。最终的代码看起来就像我在问题上的代码一样,但我用
Scan()
替换了
Find()
。我尝试对
Raw()
代码执行相同的操作,并且效果也很好。
gorm
应该提到这个机制。

© www.soinside.com 2019 - 2024. All rights reserved.