我有一个可行的模型。
class Product < ActiveRecord::Base
validates_format_of :field1, with: /\A[0-9\+\-\/\s]+\Z/, allow_nil: true
validates_format_of :field2, with: /\A[0-9\+\-\/\s]+\Z/, allow_nil: true
end
我在数据库中的某些条目无效。这些是较旧的条目。 我想运行一个找到这些无效条目的种子
Product.all.each do |product|
next if product.valid?
#
end
我想清除无效的属性。让我说,产品1在test
中的值field1
无效。现在我想清除这个领域,只有这个。
如何找到无效的字段?像product.field1.valid?
答案 0 :(得分:4)
Rails api允许您使用ActiveModel::Errors#get
方法通过密钥获取错误消息:
Product.all.each do |product|
product.valid? # => run validation callbacks
product.errors.messages # => {:field1=>["cannot be nil"]}
product.errors.get(:field1) # => ["cannot be nil"]
product.errors.get(:field2) # => nil
# `include?` and `has_key?` works too(it's aliases)
product.errors.messages # => {:field1=>["cannot be nil"]}
product.errors.include?(:field1) # => true
product.errors.include?(:field2) # => false
#
end
答案 1 :(得分:4)
这样做很容易,但有关性能的一些事项需要牢记:
这可能是一个可以接受的解决方案:
invalid_ids = []
Product.find_each(batch_size: 200) do |product|
if !product.valid?
if product.errors.include?(:field_1)
invalid_ids << product.id
end
end
end
Product.where(id: invalid_ids).update_all(field_1: nil)
答案 2 :(得分:0)