8

我正在开发一个具有几种不同模型(票证、帖子、报告等)的应用程序。每个模型中的数据都不同,我想从所有这些模型中创建一个“提要”,以全面显示 10 个最新条目(所有数据的混合)。

解决此问题的最佳方法是什么?当为用户分配工单或发布新报告时,我应该创建一个新的 Feed 模型并写入该表吗?我们也一直在寻找 STI 来构建模型引用表,或者只是创建一个聚合数据的类方法。不知道哪种方法最有效...

4

2 回答 2

6

您可以根据效率要求选择两种方法之一。

效率较低的方法是检索 10 * N 个项目并根据需要进行排序和归约:

# Fetch 10 most recent items from each type of object, sort by
# created_at, then pick top 10 of those.
@items = [ Ticket, Post, Report ].inject([ ]) do |a, with_class|
  a + with_class.find(:all, :limit => 10, :order => 'created_at DESC')
end.sort_by(&:created_at).reverse[0, 10]

另一种方法是创建一个与各种记录具有多态关联的索引表。如果您只关心一次显示 10 个,您可以使用某种 rake 任务来积极地修剪它,将其限制为每个用户 10 个,或者任何需要的范围。

于 2010-02-11T21:31:26.167 回答
0

创建一个包含属性“table_name”和“item_id”的项目模型。然后为每种数据类型创建一个部分。保存后,比如说一张票,创建一个 Item 实例:

i = Item.create(:table_name => 'tickets', :item_id => @ticket.id)

在您的 items_controller 中:

def index
   @items = Item.find(:all, :order => 'created_on DESC')
end

在视图/项目/index.erb 中:

<% @items.each do |item| %>
  <%= render :partial => item.table_name, :locals => {:item => item} %><br />
<% end %>
于 2010-02-11T18:31:16.840 回答