我正在开发一个有几种不同型号(门票,帖子,报告等)的应用程序。每个模型的数据都不同,我想从所有那些显示全面最新10个条目的模型中创建一个“提要”(所有数据的混合)。
最好的方法是什么?我是否应该在为用户分配故障单或发布新报告时创建新的Feed模型并写入该表?我们也一直在寻找STI来构建一个模型引用表,或者只是创建一个聚合数据的类方法。不确定哪种方法效率最高......
答案 0 :(得分: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个,或者任何需要的范围。
答案 1 :(得分:0)
创建包含属性“table_name”和“item_id”的Item模型。然后为每种数据类型创建一个部分。保存之后,比如说票证,创建一个Item实例:
i = Item.create(:table_name => 'tickets', :item_id => @ticket.id)
在你的items_controller中:
def index
@items = Item.find(:all, :order => 'created_on DESC')
end
在views / items / index.erb中:
<% @items.each do |item| %>
<%= render :partial => item.table_name, :locals => {:item => item} %><br />
<% end %>