Rails Counter Cache及其实现

时间:2010-03-19 09:31:40

标签: ruby-on-rails ruby ruby-on-rails-plugins

我试图抓住rails counter cache功能但却无法完全掌握它。

假设我们有3个模型

A B C

A属于B或C,具体取决于字段key_type和key_id。 key_type告诉A是属于B还是C,所以如果key_type =“B”则该记录属于B,否则它属于C.

在我的模型a.rb中,我定义了以下关联:

belongs_to :b, :counter_cache => true, :foreign_key => "key_id"
belongs_to :c, :counter_cache => true, :foreign_key => "key_id"

b和c模型文件中的

has_many :as , :conditions => {:key_type => "B"}
has_many :as , :conditions => {:key_type => "C"}

B和C模型都有一个列为as_count

问题是,每次创建a的对象时,计数b和c都会增加。

感谢任何帮助。最初我认为这可行:

belongs_to :b, :counter_cache => true, :foreign_key => "key_id", :conditions => {:key_type => "B"}
belongs_to :c, :counter_cache => true, :foreign_key => "key_id", :conditions => {:key_type => "C"}

但这没有用。

由于

2 个答案:

答案 0 :(得分:15)

看起来多态关联是解决问题的方法。

想象一下,您有一个评论模型和2个可以评论的模型:帖子和个人资料。

在Post和Profile模型中:

has_many :comments, :as => :resource

在评论模型中:

belongs_to :resource, :polymorphic => true, :counter_cache => true

不要忘记在Profile和Post模型中添加“comments_count”列并vo!

答案 1 :(得分:4)