方式一:
ruby代码方式:
machine_groups = Machine.all.group_by{|machine| machine.machine_pool_id}
这种方法是调用了数组Array类的 group_by方法
方式二:
SQL语句方式:
machine_groups = Machine.group("machine_pool_id")
>> Machine.group("machine_pool_id").to_sql
"SELECT `machines`.* FROM `machines` GROUP BY machine_pool_id"
方式二肯定会比方式一效率更高,因为是直接用SQL查出,但是方式一生成的数据会更易用
例如:
方式一产生的是一Hash对象,
machine_groups.each do |pool,machines|
pool_name = MachinePool.find(pool).name
machines.each do |machine|
machine_name = machine.name
end
end
本文对比了使用SQL语句和Ruby代码实现数据分组操作的效率,展示了SQL在大规模数据处理时的优越性,并通过实例说明了如何在Ruby中生成易于使用的分组数据。
514

被折叠的 条评论
为什么被折叠?



