首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >counter_culture sum中的深度关联column_names

counter_culture sum中的深度关联column_names
EN

Stack Overflow用户
提问于 2014-11-10 04:52:51
回答 1查看 274关注 0票数 0

在counter_culture方法中定义column_names时,可以深度关联吗?在文档和示例中,它始终是属于用于确定column_names的模型的属性。但是,如果属性属于关联的模型呢?

例如,这是可行的

代码语言:javascript
复制
# Account model
counter_culture :user,
  column_name: Proc.new { |account| account.has_billable_hours? ? 'billed_hours_sum' : nil },
  delta_column: 'billed_hours',
  column_names: { ["account.billed_hours > ?", 0] => "billed_hours_sum" }

关联示例

代码语言:javascript
复制
# Account model
counter_culture :user,
  column_name: Proc.new { |account| account.clients.has_billable_hours? ? 'billed_hours_sum' : nil },
  delta_column: 'billed_hours',
  column_names: { ["accounts.clients.billed_hours > ?", 0] => "billed_hours_sum" }

对于上面的情况,如果您可以(不能)在column_names方法中使用joins,它将如下所示

代码语言:javascript
复制
 joins(:account=>:client).where("accounts.clients.billed_hours > ?", 0)

第二个例子说明了我的问题。当您需要评估的属性不属于父模型而是关联模型时,如何定义column_names?

EN

回答 1

Stack Overflow用户

发布于 2014-11-10 05:10:06

只有在调用counter_culture_fix_counts时才需要column_names。因此,我从方法调用中提取了86‘column_names选项,并创建了一个rake任务来手动更新该计数器/列。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26833206

复制
相关文章

相似问题

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