sql - 使用 gorm golang 在多个表中进行动态列搜索
问题描述
我的场景是我有一个带有搜索选项的网格,用户可以在其中选择列并进行搜索,网格数据来自各种表。我附上了网格的示例屏幕。
所以我正在尝试为搜索创建一个动态查询,但问题是我只能在主表(schema.Robot)中搜索,而不是在预加载表中搜索。每当我尝试从 Preload 表中搜索数据数据时,让 RobotModel 表中的时间低于错误
pq:缺少表“robot_models”的 FROM 子句条目
这是我的代码
func (r *RobotsRepository) GetRobotsSummary(listParams viewmodel.ListParams, companyID uint) ([]*schema.Robot, int, error) {
mrobots := []*schema.Robot{}
var count int
var order string
if listParams.SortColumn == "" {
listParams.SortColumn = "id"
listParams.SortOrder = 1
} else {
listParams.SortColumn = util.Underscore(listParams.SortColumn)
}
if listParams.SortOrder == 0 {
order = "ASC"
} else {
order = "DESC"
}
var searchQuery string
if listParams.SearchText != "" {
switch listParams.SearchColumn {
case "Robot":
listParams.SearchColumn = "name"
case "Model":
listParams.SearchColumn = "robot_models.name"
}
searchQuery = listParams.SearchColumn +" LIKE '%"+ listParams.SearchText +"%' and Company_ID = " + fmt.Sprint(companyID)
}else{
searchQuery = "Company_ID = " + fmt.Sprint(companyID)
}
orderBy := fmt.Sprintf("%s %s", listParams.SortColumn, order)
err := r.Conn.
Preload("RobotModel", func(db *gorm.DB) *gorm.DB {
return db.Select("ID,Name")
}).
Preload("Task", func(db *gorm.DB) *gorm.DB {
return db.Where("Task_Status in ('In-Progress','Pending')").Select("ID, Task_Status")
}).
Preload("CreatedUser", func(db *gorm.DB) *gorm.DB {
return db.Select("ID,Display_Name")
}).
Preload("UpdatedUser", func(db *gorm.DB) *gorm.DB {
return db.Select("ID,Display_Name")
}).
Where(searchQuery).
Order(orderBy).
Offset(listParams.PageSize * (listParams.PageNo - 1)).
Limit(listParams.PageSize).
Find(&mrobots).Error
r.Conn.Model(&schema.Robot{}).Where(searchQuery).Count(&count)
return mrobots, count, err
}
在 searchQuery 变量中,我正在存储我的动态查询。我的问题是如何搜索预加载表列的数据
这是我试图使用 gorm 实现的 sql 查询
SELECT robots.id,robots.name,robot_models.name as
model_name,count(tasks.task_status) as task_on_hand,
robots.updated_at,users.user_name as updated_by
FROM rfm.robots as robots
left join rfm.tasks as tasks on tasks.robot_id = robots.id and
tasks.task_status in ('In-Progress','Pending')
left join rfm.robot_models as robot_models on robot_models.id =
robots.robot_model_id
left join rfm.users as users on users.id = robots.updated_by
WHERE robot_models.name::varchar like '%RNR%' and robots.deleted_at is null
GROUP BY robots.id,robot_models.name,users.user_name
ORDER BY task_on_hand DESC LIMIT 2 OFFSET 0
对不起英语不好!
解决方案
即使您正在预加载,您仍然需要在对其他表上的列进行过滤和排序时显式使用连接。预加载用于急切地加载数据以映射到模型中,而不是连接表。
链上这样的东西:
.Joins("LEFT JOIN rfm.robot_models AS robot_models ON robot_models.id = robots.robot_model_id")
如果您可以使用此技术使用关键字,我不肯定AS
,但如果不能,那么相应地调整您的查询应该很容易。
推荐阅读
- r - 如何在此情节中添加图例?
- python - 如何在熊猫中将“0天00:39:00”转换为只有39?
- c++ - 具有非 ASCII 文件名的 Microsoft Speech to Text
- ios - Swift中的“[self] in”和“[weak self] in”有什么区别?
- python - PyCryptodome AES,“EcbMode”对象没有属性“encrypt_and_digest”
- wolfram-mathematica - 带有符号的矩阵的复共轭
- c# - 如何从文本框或富文本框或 ETC 中获取“组分隔符”、0x1D 字符。C#
- mongodb - MongoDB 聚合管道的操作超时
- r - 创建一个函数来循环数据帧以在 R 中创建显着相关性的分布
- javascript - 未捕获的错误:不匹配的匿名定义():使用汇总 [UMD] 构建时:如何解决?