首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >一种动态的操作调用方法

一种动态的操作调用方法
EN

Stack Overflow用户
提问于 2015-04-24 14:11:30
回答 1查看 84关注 0票数 2

我有一段代码,其中涉及一个雷尔操作,并希望优化它。

代码语言:javascript
复制
case group_type
        when "week"
            gmv = OrderItem.joins(:order).where(order: {order_date: from_date..to_date }).group_by_week("order.order_date").sum("sub_total")
        when "month"
             gmv = OrderItem.joins(:order).where(order: {order_date: from_date..to_date }).group_by_month("order.order_date").sum("sub_total")
        when "day"
             gmv = OrderItem.joins(:order).where(order: {order_date: from_date..to_date }).group_by_day("order.order_date").sum("sub_total")
        end 

我想用一种方法把它写成一行,只需用"group_by_#{group_type}“代替。

我可以用伊娃。但使用eval并不是一种好的做法。

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-04-24 14:18:18

您可以使用发送。所以你的代码是:

代码语言:javascript
复制
OrderItem.joins(:order).where(order: {order_date: from_date..to_date }).public_send("group_by_#{group_type}", "order.order_date").sum("sub_total")
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29849745

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档