私はこれを持っています
User.joins(:notifications).joins(:company_users).joins(:role_users).where("notifications.id = ? AND role_users.role_id != '1' AND (company_users.company_id = ? OR users.company_id = ?)", notification.id, p.company_id, p.company_id)
=> []
このSQLを生成する
SELECT `users`.* FROM `users`
INNER JOIN `subscriptions` ON `users`.`id` = `subscriptions`.`user_id`
INNER JOIN `notifications` ON `notifications`.`id` = `subscriptions`.`notification_id`
INNER JOIN `company_users` ON `company_users`.`user_id` = `users`.`id`
INNER JOIN `role_users` ON `role_users`.`user_id` = `users`.`id`
WHERE (notifications.id = 1
AND role_users.role_id != '1'
AND (company_users.compcany_id = 67 OR users.company_id = 67))
問題は、私はcompany_usersに参加する必要があり、レールでそれを達成する方法がわからないことです
私はfind_by_sqlでこれを行うことができることを知っています。