基本上,我想采用一组典型的ActiveRecord关系,使其看起来像一个更简单的关系。
假设我有一个典型的Post
,Comment
,User
,其中一篇帖子有很多评论和评论都有用户。
现在,假设我想将以下数据放入视图中。 (假设所有需要的数据都可以通过单个Arel语句读取)。
post.title
post.tag.name
post.comments.last
post.comments.last.user.full_name
我想通过以下方法通过名为PostSummary的新对象访问它们:
post_summary.title
post_summary.tag_name
post_summary.last_comment
post_summary.last_comment_user
到目前为止,并不太棘手。它可以通过OpenStruct和一些映射完成,但我希望PostSummary是一个只读的ActiveRecord :: Relation对象,它允许你执行以下操作:
PostSummary.first.attributes #=> [title, tag_name, last_comment, last_comment_user]
PostSummary.count #=> 42
...
我确信通过大量工作可以实现这一点,但是有没有设置过这样做?