Rails Triple Join

use*_*382 3 ruby activerecord ruby-on-rails ruby-on-rails-3

我有3种型号Report,ServerPlatform.我需要执行一个查询,该查询涉及三个连接所有3个模型并基于此进行查询.但每当我尝试三次加入时,我都会收到以下错误

ActiveRecord :: ConfigurationError:找不到名为"platform"的关联; 也许你拼错了吗?

这是我的模特

报告

class Report < ActiveRecord::Base

 belongs_to :server

 delegate :company_id, :to => :server

    class << self

        def method(url, base_url)
            Report.joins(:server).joins(:platform).where(:platforms => {:company_id => 5}).all
        end
    end

end
Run Code Online (Sandbox Code Playgroud)

服务器

class Server < ActiveRecord::Base

 has_many :reports
 belongs_to :platform

end
Run Code Online (Sandbox Code Playgroud)

平台

class Platform < ActiveRecord::Base

 attr_accessible :company_id

 has_many :servers

end
Run Code Online (Sandbox Code Playgroud)

tih*_*hom 5

试试这个:(注意splatform需要它,因为该表名是复数):

Report.joins(:server => :platform).where(:platforms => {:company_id => 5}).all
Run Code Online (Sandbox Code Playgroud)