我正在尝试使用预先加载来优化我的代码,但是当调用函数时,会在日志中执行查询。
@votes_list = Vote.joins(:user => :profile).where(:post_id => post.id)
@male_votes = @votes_list.where(:profiles => { :gender => 1 }).count
@female_votes = @votes_list.where(:profiles => { :gender => 2 }).count
我试图在第一个之后进行一些查询,而不需要从数据库中获取,该怎么做?
答案 0 :(得分:2)
您希望每次投票都热切地加载用户及其个人资料。然后,您可以在个人资料中选择按性别划分的内存投票子集。
@votes_list = Vote.where(:post_id => post.id, :include => { :user => :profile })
@male_votes = @votes_list.select {|v| v.user.profile.gender == 1}
@female_votes = @votes_list.select {|v| v.user.profile.gender == 2}