如果我尝试进行计数器缓存,为什么会出现此错误?

时间:2013-01-07 13:31:39

标签: ruby-on-rails ruby-on-rails-3 counter-cache

我正在使用Rails 3.2.6。当我尝试进行计数器缓存时,我会以某种方式出现此错误 我怎样才能解决这个问题?我在这个应用程序上做了同样的事情,但没有在这个模型上 我的代码或关联有什么问题?

命令 bundle exec rake db:migrate

日志

==  AddCommunityTopicsCountToCommunity: migrating =============================
-- add_column(:communities, :community_topics_count, :integer, {:default=>0})
   -> 0.0635s
rake aborted!
An error has occurred, all later migrations canceled:

community_topics_count is marked as readonly

模型/ community.rb

...
has_many :community_topics
...

模型/ community_topic.rb

...
belongs_to :community, counter_cache: true
...

迁移文件

class AddCommunityTopicsCountToCommunity < ActiveRecord::Migration
  def up
    add_column :communities, :community_topics_count, :integer, :default => 0

    Community.reset_column_information
    Community.all.each do |p|
      p.update_attribute :community_topics_count, p.community_topics.length
    end
  end

  def down
    remove_column :communities, :community_topics_count
  end
end

3 个答案:

答案 0 :(得分:3)

class AddCommunityTopicsCountToCommunity < ActiveRecord::Migration
  def up
    add_column :communities, :community_topics_count, :integer, :default => 0

    Community.reset_column_information
    Community.all.each do |c|
      Community.reset_counters(c.id, :community_topics)
    end
  end
end

答案 1 :(得分:2)

当您添加conter_cache时,无法使用Rails更新它,默认情况下将其设置为只读。

您可以将updated_attribute替换为update_column,以跳过任何验证或回调,从而绕过此问题。

答案 2 :(得分:2)

conter_cache有自己的处理方法,请查看docs了解详情。

在您的情况下,您可以使用类似

的内容
Community.all.each do |p|
  Community.reset_counters(p.id, :community_topics)
end