对于添加的数据库字段,迁移失败“未找到方法”

时间:2019-11-12 15:46:32

标签: ruby-on-rails postgresql rails-migrations

我正在Rails 6应用程序上进行大量迁移。当我进行迁移时,尝试从上一个迁移步骤访问新添加的字段的特定属性时,它总是会失败。失败之后,我只需重新运行迁移即可,并且可以正常工作,显然它可以第二次找到该属性。对这里可能发生的事情有任何想法吗?

deleted_customer = Customer.new(first_name:"Deleted",last_name:"Deleted",active:false,customer_type_id:CustomerType.first.id)
deleted_customer.save(validate:false)

StandardError: An error has occurred, this and all later migrations canceled: unknown attribute 'active' for Customer.

在迁移失败之前进行迁移

add_column :customers, :active, :boolean, default: true

我想念什么吗?

1 个答案:

答案 0 :(得分:1)

Rails在首次访问模型时读取架构信息并将其缓存(这样,您不必在每次访问模型时都读取数据库架构)。

您可以重置该缓存:

Customer.connection.schema_cache.clear!
Customer.reset_column_information