use*_*382 3 ruby activerecord ruby-on-rails ruby-on-rails-3
我有3种型号Report,Server和Platform.我需要执行一个查询,该查询涉及三个连接所有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)
试试这个:(注意s在platform需要它,因为该表名是复数):
Report.joins(:server => :platform).where(:platforms => {:company_id => 5}).all
Run Code Online (Sandbox Code Playgroud)