我已经开始使用查询分析器,它会警告我有关相同的查询。
就上下文而言,我在页面上加载了 25 个“帖子”,当前用户可以“加星标”一个帖子:
0.018s 25 个相同的查询
SELECT SQL_NO_CACHE N AS one FROM 'stars' WHERE 'stars'.'post_id' = N AND 'stars'.'user_id' = N LIMIT N
这是 User 模型中的方法:
def has_starred_post?(post)
return false if post.nil?
Star.where(post_id: post.id, user_id: self.id).exists?
end
如何通过减少查询数量来满足此警告?
更新:
根据 Taryn East 的提示,我将User
模型方法更新为:
def has_starred_post?(post)
return false if post.nil?
self.stars.where(post_id: post.id).exists?
# OR post.stars.where(:user_id => self.id).exists?
end
虽然这允许我关联/缓存属于用户的星星,但我仍然需要where
检查这些星星是否属于帖子。正确的?