gpt4 book ai didi

ruby-on-rails - rails : Group By join table

转载 作者:行者123 更新时间:2023-12-05 03:03:33 25 4
gpt4 key购买 nike

我正在尝试按委托(delegate)连接表进行分组。我有一个任务表,每个任务都有一个 project_id。以下代码在我的 Controller 中运行良好,可以按项目分组:

@task = Task.joins(:project).joins(:urgency).where(urgencies: {urgency_value: 7}).group_by(&:project_id)

这将返回一个散列,其中键是我加入的内容,然后索引包含该组中的每个任务。然后我可以遍历每个任务以检索其属性。

但是,每个项目都属于一个工作区(通过 workspace_id)。我想要的是具有相同的查询但按工作区分组。我的最终目标是创建一个表格,在一列中显示工作区名称,在第二列中显示该工作区的任务数。

我尝试了很多组合,搜索了很多论坛,但几个小时后仍然无法破解。

最佳答案

如果您的唯一目标是获取每个工作区的任务计数,我认为您需要不同的查询。

@workspaces_with_task_counts = 
Workspace
.joins(:projects)
.joins(:tasks)
.select('workspaces.name, count(tasks.id) as task_count')
.group(:workspace_id)

然后您可以像这样访问计数:

@workspaces_with_task_counts.each do |workspace|
puts "#{workspace.name}: #{workspace.task_count}"
end

编辑 1

我想这就是你想要的:

Workspace
.joins(projects: { tasks: :urgencies })
.where(urgencies: {urgency_value: 7})
.group(:name)
.count

这会生成一个散列,其中包含所有工作区,其中至少有一个 urgency_value 为 7 的任务,按名称,以及该工作区中的任务数:

{"workspace1"=>4, "workspace2"=>1}

编辑 2

SQL 无法在单个查询中同时返回详细信息和摘要信息。但是,我们可以获取所有数据,然后使用 Ruby 的 group_by 方法将其汇总到内存中:

Task
.joins(project: :workspace)
.includes(project: :workspace)
.group_by { |task| task.project.workspace.name }

这会产生以下数据结构:

{
"workspace1": [task, task, task],
"workspace2": [task, task],
"workspace3": [task, task, task, task]
}

但是,这样做是有代价的。在内存中分组是一个昂贵的过程。运行该查询 10,000 次大约需要 15 秒。

事实证明,执行两个 SQL 查询实际上快了两个数量级,大约 0.2 秒。以下是查询:

tasks = Task.joins(project: :workspace).includes(project: :workspace)
counts = tasks.group('workspaces.name').count

第一个查询获取所有任务并预加载它们相关的项目和工作区数据。第二个查询使用 ActiveRecord 的 group 子句构造 SQL 语句来汇总数据。它返回这个数据结构:

{ "workspace1": 3, "workspace2": 2, "workspace3": 4 }

数据库在集合操作方面非常高效。在数据库中完成这项工作几乎总是比在 Ruby 中快得多。

关于ruby-on-rails - rails : Group By join table,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53771386/

25 4 0