我有这些机型:
- class Children < ActiveRecord::Base
- has_many :tickets
- has_many :movies,through: :tickets
- end
- class Movie < ActiveRecord::Base
- has_many :tickets
- has_many :childrens,through: :tickets
- belongs_to :cinema
- end
- class Ticket < ActiveRecord::Base
- belongs_to :movie,counter_cache: true
- belongs_to :children
- end
- class Cinema < ActiveRecord::Base
- has_many :movies,dependent: :destroy
- has_many :childrens,through: :movies
- end
我现在需要的是“电影院”的页面,我想打印这个电影院的孩子的总和(数量,大小?),所以我写道:@H_404_5@
>在cinemas_controller.rb中:@H_404_5@
@childrens = @ cinema.childrens.uniq@H_404_5@
>在电影院/ show.html.erb:@H_404_5@
<%@ childrens.each do | children | %><%= children.movies.size%><%end%>@H_404_5@
但显然我有弹珠宝,提醒我的Counter_cache,我不知道在哪里放这个counter_cache,因为电影的不同的id.@H_404_5@
而且没有counter_cache,我不是我想要的,因为我想要一个数字,这个电影院里有多少孩子从这个电影院的许多日子里把他们从门票里拿走.@H_404_5@
如何?@H_404_5@
UPDATE@H_404_5@
- <% @childrens.each do |children| %>
- <%= children.movies.where(cinema_id: @cinema.id).size %>
- <% end %>
宝石子弹不要说我什么,一切都正常工作.@H_404_5@
解决方法
这可能会帮助你.
- @childrens_count = @cinema.childrens.joins(:movies).group("movies.children_id").count.to_a