我正在构建一个模型来跟踪给定用户已阅读的帖子(在 Rails 3 中)。跟踪这个的表是“读数”。阅读属于:用户和:帖子,两者都有很多:阅读。当用户看到一篇文章时,它被标记为已读,并使用 user_id 和 post_id 创建一个“正在阅读”。这似乎工作正常,但现在我正在尝试编写一个只返回给定用户未读帖子的范围。查找已读帖子工作正常:
scope :read, lambda { |user_id = nil |
user_id.nil? ? {} : joins(:readings).where('readings.user_id = :user_id', :user_id => user_id)
}
然而,我试图返回这组的补充(未读帖子)失败了。如何才能做到这一点?有没有一种通用的方法来编写一个只返回另一个(这里,:read)的补码的范围(方法)?我也很乐意将其编写为与作用域相同的类方法。
请记住,阅读仅在阅读帖子时创建,因此新帖子将没有阅读。这似乎比为每个新帖子为每个用户创建条目更经济。
编辑:好的,我越来越近了 - 下面的范围几乎可以工作,但不需要帖子的所有读数都不等于 user_id。因此,如果用户#1 已阅读帖子,用户#2 也已阅读,则查询其他阅读并发现不相等。因此,该帖子被错误地发现为未读。
scope :unread, lambda { |user_id = nil |
user_id.nil? ? {} : includes(:readings).where('(readings.user_id IS NULL OR readings.user_id != :user_id)', :user_id => user_id)
}