#primary_key(klass) (private)
[ GitHub ]# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 151
def primary_key(klass) reflection.association_primary_key(klass) end
123456789_123456789_123456789_123456789_123456789_
Relationships & Source Files | |
Extension / Inclusion / Inheritance Descendants | |
Subclasses:
|
|
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
self,
SingularAssociation ,
Association
|
|
Instance Chain:
self,
SingularAssociation ,
Association
|
|
Inherits: |
ActiveRecord::Associations::SingularAssociation
|
Defined in: | activerecord/lib/active_record/associations/belongs_to_association.rb |
Association
- InheritedAssociation
- Inherited#collection? | Whether the association represents a single record or a collection of records. |
#disable_joins, | |
#loaded? | Has the target been already loaded? |
#options, #owner, #reflection, | |
#stale_target? | The target is stale if the target no longer points to the record(s) that the relevant foreign_key(s) refers to. |
#target, | |
#target= | Sets the target of this association to |
#find_target?, | |
#foreign_key_present? | Returns true if there is a foreign key present on the owner which references the target. |
#violates_strict_loading? |
SingularAssociation
- Inherited#build, | |
#force_reload_reader | Implements the reload reader method, e.g. |
#reader | Implements the reader method, e.g. |
#reset | Resets the loaded flag to |
#writer | Implements the writer method, e.g. |
#_create_record, #find_target, #replace, #scope_for_create, #set_new_record |
Association
- Inherited#async_load_target, #create, #create!, #extensions, #initialize_attributes, #inversed_from, #inversed_from_queries, | |
#klass | Returns the class of the target. |
#load_target | Loads the target if needed and returns it. |
#loaded! | Asserts the target has been loaded setting the loaded flag to |
#marshal_dump | We can’t dump @reflection and @through_reflection since it contains the scope proc. |
#marshal_load, | |
#reload | Reloads the target and returns |
#remove_inverse_instance | Remove the inverse association, if possible. |
#reset | Resets the loaded flag to |
#reset_negative_cache, #reset_scope, #scope, | |
#set_inverse_instance | Set the inverse association, if possible. |
#set_inverse_instance_from_queries, #set_strict_loading, | |
#association_scope | The scope for this association. |
#build_record, #enqueue_destroy_association, | |
#ensure_klass_exists! | Reader and writer methods call this so that consistent errors are presented when the association target class does not exist. |
#find_target, | |
#foreign_key_for? | Returns true if record contains the foreign_key. |
#inversable?, #inverse_association_for, | |
#inverse_reflection_for | Can be redefined by subclasses, notably polymorphic belongs_to The record parameter is necessary to support polymorphic inverses as we must check for the association in the specific class of the record. |
#invertible_for? | Returns true if inverse association on the given record needs to be set. |
#matches_foreign_key?, | |
#raise_on_type_mismatch! | Raises |
#scope_for_create, | |
#skip_statement_cache? | Returns true if statement cache should be skipped on the association reader. |
#skip_strict_loading, | |
#stale_state | This should be implemented to return the values of the relevant key(s) on the owner, so that when stale_state is different from the value stored on the last find_target, the target is stale. |
#target_scope | Can be overridden (i.e. in |
This class inherits a constructor from ActiveRecord::Associations::Association
Boolean
(readonly, private)
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 124
def find_target? !loaded? && foreign_key_present? && klass end
Boolean
(readonly, private)
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 155
def foreign_key_present? Array(reflection.foreign_key).all? { |fk| owner._read_attribute(fk) } end
Boolean
(readonly, private)
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 128
def require_counter_update? reflection.counter_cache_column && owner.persisted? end
Boolean
(readonly)
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 90
def saved_change_to_target? owner.saved_change_to_attribute?(reflection.foreign_key) end
Boolean
(readonly)
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 82
def target_changed? owner.attribute_changed?(reflection.foreign_key) || (!foreign_key_present? && target&.new_record?) end
Boolean
(readonly)
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 86
def target_previously_changed? owner.attribute_previously_changed?(reflection.foreign_key) end
Boolean
(readonly)
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 55
def updated? @updated end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 59
def decrement_counters update_counters(-1) end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 67
def decrement_counters_before_last_save if reflection.polymorphic? model_type_was = owner.attribute_before_last_save(reflection.foreign_type) model_was = owner.class.polymorphic_class_for(model_type_was) if model_type_was else model_was = klass end foreign_key_was = owner.attribute_before_last_save(reflection.foreign_key) if foreign_key_was && model_was < ActiveRecord::Base update_counters_via_scope(model_was, foreign_key_was, -1) end end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 46
def default(&block) writer(owner.instance_exec(&block)) if reader.nil? end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 7
def handle_dependency return unless load_target case [:dependent] when :destroy raise ActiveRecord::Rollback unless target.destroy when :destroy_async if reflection.foreign_key.is_a?(Array) primary_key_column = reflection.active_record_primary_key id = reflection.foreign_key.map { |col| owner.public_send(col) } else primary_key_column = reflection.active_record_primary_key id = owner.public_send(reflection.foreign_key) end association_class = if reflection.polymorphic? owner.public_send(reflection.foreign_type) else reflection.klass end enqueue_destroy_association( owner_model_name: owner.class.to_s, owner_id: owner.id, association_class: association_class.to_s, association_ids: [id], association_primary_key_column: primary_key_column, ensuring_owner_was_method: .fetch(:ensuring_owner_was, nil) ) else target.public_send( [:dependent]) end end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 63
def increment_counters update_counters(1) end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 41
def inversed_from(record) replace_keys(record) super end
Boolean
(private)
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 159
def invertible_for?(record) inverse = inverse_reflection_for(record) inverse && (inverse.has_one? || inverse.klass.has_many_inversing) end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 151
def primary_key(klass) reflection.association_primary_key(klass) end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 95
def replace(record) if record raise_on_type_mismatch!(record) set_inverse_instance(record) @updated = true elsif target remove_inverse_instance(target) end replace_keys(record, force: true) self.target = record end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 132
def replace_keys(record, force: false) reflection_fk = reflection.foreign_key if reflection_fk.is_a?(Array) target_key_values = record ? Array(primary_key(record.class)).map { |key| record._read_attribute(key) } : [] if force || reflection_fk.map { |fk| owner._read_attribute(fk) } != target_key_values reflection_fk.each_with_index do |key, index| owner[key] = target_key_values[index] end end else target_key_value = record ? record._read_attribute(primary_key(record.class)) : nil if force || owner._read_attribute(reflection_fk) != target_key_value owner[reflection_fk] = target_key_value end end end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 50
def reset super @updated = false end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 164
def stale_state owner._read_attribute(reflection.foreign_key) { |n| owner.send(:missing_attribute, n, caller) } end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 109
def update_counters(by) if require_counter_update? && foreign_key_present? if target && !stale_target? target.increment!(reflection.counter_cache_column, by, touch: reflection. [:touch]) else update_counters_via_scope(klass, owner._read_attribute(reflection.foreign_key), by) end end end
# File 'activerecord/lib/active_record/associations/belongs_to_association.rb', line 119
def update_counters_via_scope(klass, foreign_key, by) scope = klass.unscoped.where!(primary_key(klass) => foreign_key) scope.update_counters(reflection.counter_cache_column => by, touch: reflection. [:touch]) end