跳过到内容 跳过到搜索

Active Record 属性方法脏值

提供了一种跟踪 Active Record 模型中更改的方法。它添加了来自 ActiveModel::Dirty 的所有方法,并添加了特定于数据库的方法。

新创建的 Person 对象未更改

class Person < ActiveRecord::Base
end

person = Person.create(name: "Allison")
person.changed? # => false

更改姓名

person.name = 'Alice'
person.name_in_database          # => "Allison"
person.will_save_change_to_name? # => true
person.name_change_to_be_saved   # => ["Allison", "Alice"]
person.changes_to_save           # => {"name"=>["Allison", "Alice"]}

保存更改

person.save
person.name_in_database        # => "Alice"
person.saved_change_to_name?   # => true
person.saved_change_to_name    # => ["Allison", "Alice"]
person.name_before_last_save   # => "Allison"

类似于 ActiveModel::Dirty,方法可以调用为 saved_change_to_name? 或通过将参数传递给通用方法 saved_change_to_attribute?("name") 来调用。

方法
A
C
H
R
S
W
包含的模块

实例公共方法

attribute_before_last_save(attr_name)

返回上次保存之前属性的原始值。

此方法在 after 回调中很有用,用于获取触发回调运行的保存之前属性的原始值。它可以调用为 name_before_last_save 而不是 attribute_before_last_save("name")

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 108
def attribute_before_last_save(attr_name)
  mutations_before_last_save.original_value(attr_name.to_s)
end

attribute_change_to_be_saved(attr_name)

返回将在下次保存时持久化的属性更改。

此方法在验证和 before 回调中很有用,用于查看保存记录时将发生的属性更改。它可以调用为 name_change_to_be_saved 而不是 attribute_change_to_be_saved("name")

如果属性将更改,结果将是一个数组,其中包含将要保存的原始值和新值。

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 152
def attribute_change_to_be_saved(attr_name)
  mutations_from_database.change_to_attribute(attr_name.to_s)
end

attribute_in_database(attr_name)

返回数据库中属性的值,而不是下次保存记录时将持久化的内存中值。

此方法在验证和 before 回调中很有用,用于查看在保存任何更改之前属性的原始值。它可以调用为 name_in_database 而不是 attribute_in_database("name")

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 164
def attribute_in_database(attr_name)
  mutations_from_database.original_value(attr_name.to_s)
end

attributes_in_database()

返回一个哈希,其中包含下次保存记录时将更改的属性。

哈希键是属性名称,哈希值是数据库中原始属性值(与将要保存的内存中值相反)。

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 191
def attributes_in_database
  mutations_from_database.changed_values
end

changed_attribute_names_to_save()

返回一个数组,其中包含下次保存记录时将更改的任何属性的名称。

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 181
def changed_attribute_names_to_save
  mutations_from_database.changed_attribute_names
end

changes_to_save()

返回一个哈希,其中包含将在下次保存时持久化的所有更改。

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 175
def changes_to_save
  mutations_from_database.changes
end

has_changes_to_save?()

下次调用 save 是否有任何更改要持久化?

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 169
def has_changes_to_save?
  mutations_from_database.any_changes?
end

reload(*)

reload 记录并清除更改的属性。

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 63
def reload(*)
  super.tap do
    @mutations_before_last_save = nil
    @mutations_from_database = nil
  end
end

saved_change_to_attribute(attr_name)

返回上次保存期间属性的更改。如果属性已更改,结果将是一个数组,其中包含原始值和保存的值。

此方法在 after 回调中很有用,用于查看触发回调运行的保存期间属性的更改。它可以调用为 saved_change_to_name 而不是 saved_change_to_attribute("name")

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 98
def saved_change_to_attribute(attr_name)
  mutations_before_last_save.change_to_attribute(attr_name.to_s)
end

saved_change_to_attribute?(attr_name, **options)

此属性在我们上次保存时是否已更改?

此方法在 after 回调中很有用,用于确定触发回调运行的保存期间属性是否已更改。它可以调用为 saved_change_to_name? 而不是 saved_change_to_attribute?("name")

选项

from

如果指定,此方法将返回 false,除非原始值等于给定值。

to

如果指定,此方法将返回 false,除非值将更改为给定值。

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 86
def saved_change_to_attribute?(attr_name, **options)
  mutations_before_last_save.changed?(attr_name.to_s, **options)
end

saved_changes()

返回一个哈希,其中包含刚刚保存的所有更改。

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 118
def saved_changes
  mutations_before_last_save.changes
end

saved_changes?()

上次调用 save 是否有任何更改?

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 113
def saved_changes?
  mutations_before_last_save.any_changes?
end

will_save_change_to_attribute?(attr_name, **options)

下次保存时此属性是否会更改?

此方法在验证和 before 回调中很有用,用于确定下次调用 save 是否会更改特定属性。它可以调用为 will_save_change_to_name? 而不是 will_save_change_to_attribute?("name")

选项

from

如果指定,此方法将返回 false,除非原始值等于给定值。

to

如果指定,此方法将返回 false,除非值将更改为给定值。

# File activerecord/lib/active_record/attribute_methods/dirty.rb, line 138
def will_save_change_to_attribute?(attr_name, **options)
  mutations_from_database.changed?(attr_name.to_s, **options)
end