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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值