我正在尝试使用印象派 gem来跟踪关系中的访问。我的写作方法效果很好:
@document.publications.each do |publication|
impressionist(publication)
end我有一个类似于这样的has_many, :through关系(这里简化了,但一切都很好):
class Document
has_many :components, :through => :publications
end我只是遇到了一个问题,编写一个查询来获取基于组件的相关印象。我的失败代码目前如下所示:
<% document.components.each do |component| %>
<%= component.publications.where(:document_id => document.id).impressionist_count %>
<% end %>我得到一个无方法错误,如下所示:
undefined method 'impressionist_count' for #<ActiveRecord::Relation:blah我知道我写错了失败的代码,但我很难找到正确的方法来编写它。
发布于 2013-07-24 01:13:58
您需要在您的协会中设置:counter_cache
看这段视频,http://railscasts.com/episodes/23-counter-cache-column解释得很清楚
https://stackoverflow.com/questions/17823543
复制相似问题