我正在开发一个具有几种不同模型(门票,帖子,报告等)的应用程序.每个模型中的数据都不同,我想从所有那些显示全面最近10个条目的模型中创建一个“提要”(所有数据的混合).
最好的方法是什么?我是否应该在为用户分配故障单或发布新报告时创建新的Feed模型并写入该表?我们也一直在寻找STI来构建一个模型引用表,或者只是创建一个聚合数据的类方法.不确定哪种方法效率最高……
解决方法
您可以根据效率要求采用两种方式之一.
效率较低的方法是检索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,或者需要任何范围.