0

我正在尝试通过预先加载来优化我的代码,但是无论何时调用函数,都会在日志中执行查询。

@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

我试图在第一个查询之后进行一些查询,而无需从数据库中获取,该怎么做?

4

1 回答 1

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}
于 2013-02-06T17:22:39.253 回答