导轨:如何建立一个有效的关系范围遍历多个表? [英] rails: how do I build an active-relation scope to traverse many tables?

查看:190
本文介绍了导轨:如何建立一个有效的关系范围遍历多个表?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有这些表和关系:

user has_many projects
project has_many tasks
task has_many actions

我想建立一个范围,让我来选择所有的当前用户的行为,不管他们属于哪个项目或任务来。

I would like to build a scope that allows me to select all of the current users actions, regardless of what project or task they belong to.

感谢

推荐答案

我发现一些作品。

在操作模式:

def self.owned_by (user)
    joins("join tasks on actions.task_id = tasks.id").
    joins("join projects on tasks.list_id = projects.id").
    where("projects.user_id = ?" , user.id)
end

从控制台:

u=User.find(1)
Action.owned_by(u).count

 => 521 # which is correct

我MOT知道它的最好办法做到这一点,因为我是一个有点新的SQL。我得到它可以更简洁的感觉。

I'm mot sure if its the best way to do it as I'm a bit new to sql. I get the feeling it could be made more concise.

修改稍微好一点

 Action.joins(:task => [{:project => :user }]).where(:projects => {:user_id =>  user.id })

这篇关于导轨:如何建立一个有效的关系范围遍历多个表?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆