日期:2014-05-16  浏览次数:21222 次

Rails中数据库查询分组的几种方式

方式一:

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