将两个不同的ActiveRecord集合合并为一个

我想创建所有公司活动的视觉时间表。 时间轴的HTML是使用loop构建的。

为简单起见,我们假设有两种模式HireDeal 。 两个模型都具有date属性和一些模型特定属性。 如何合并两个模型的ActiveRecord结果,然后按date对组合的哈希进行order将其组合成一个我可以循环的哈希?

好吧,假设查询HireDeal模型的结果是一个对象数组( 集合 ),那么你只需使用+将它们连接成一个新数组,并按datesort_by对项目进行排序:

 combined = ( Hire.all + Deal.all ).sort_by(&:date) 

或使用concat将一个集合与另一个集合连接起来:

 combined = Hire.all.concat( Deal.all ).sort_by(&:date)