Module: ActiveRecord::AttributeMethods::PrimaryKey::ClassMethods

Defined in:
lib/active_record/attribute_methods/primary_key.rb

Constant Summary collapse

ID_ATTRIBUTE_METHODS =
%w(id id= id? id_before_type_cast id_was id_in_database id_for_database).to_set
PRIMARY_KEY_NOT_SET =
BasicObject.new

Instance Method Summary collapse

Instance Method Details

#composite_primary_key?Boolean

:nodoc:

Returns:

  • (Boolean)


118
119
120
# File 'lib/active_record/attribute_methods/primary_key.rb', line 118

def composite_primary_key? # :nodoc:
  primary_key.is_a?(Array)
end

#dangerous_attribute_method?(method_name) ⇒ Boolean

Returns:

  • (Boolean)


104
105
106
# File 'lib/active_record/attribute_methods/primary_key.rb', line 104

def dangerous_attribute_method?(method_name)
  super && !ID_ATTRIBUTE_METHODS.include?(method_name)
end

#get_primary_key(base_name) ⇒ Object

:nodoc:



136
137
138
139
140
141
142
143
144
145
146
147
148
# File 'lib/active_record/attribute_methods/primary_key.rb', line 136

def get_primary_key(base_name) # :nodoc:
  if base_name && primary_key_prefix_type == :table_name
    base_name.foreign_key(false)
  elsif base_name && primary_key_prefix_type == :table_name_with_underscore
    base_name.foreign_key
  else
    if ActiveRecord::Base != self && table_exists?
      connection.schema_cache.primary_keys(table_name)
    else
      "id"
    end
  end
end

#instance_method_already_implemented?(method_name) ⇒ Boolean

Returns:

  • (Boolean)


100
101
102
# File 'lib/active_record/attribute_methods/primary_key.rb', line 100

def instance_method_already_implemented?(method_name)
  super || primary_key && ID_ATTRIBUTE_METHODS.include?(method_name)
end

#primary_keyObject

Defines the primary key field – can be overridden in subclasses. Overwriting will negate any effect of the primary_key_prefix_type setting, though.



111
112
113
114
115
116
# File 'lib/active_record/attribute_methods/primary_key.rb', line 111

def primary_key
  if PRIMARY_KEY_NOT_SET.equal?(@primary_key)
    @primary_key = reset_primary_key
  end
  @primary_key
end

#primary_key=(value) ⇒ Object

Sets the name of the primary key column.

class Project < ActiveRecord::Base
  self.primary_key = 'sysid'
end

You can also define the #primary_key method yourself:

class Project < ActiveRecord::Base
  def self.primary_key
    'foo_' + super
  end
end

Project.primary_key # => "foo_id"


165
166
167
168
169
# File 'lib/active_record/attribute_methods/primary_key.rb', line 165

def primary_key=(value)
  @primary_key        = derive_primary_key(value)
  @quoted_primary_key = nil
  @attributes_builder = nil
end

#quoted_primary_keyObject

Returns a quoted version of the primary key name, used to construct SQL statements.



124
125
126
# File 'lib/active_record/attribute_methods/primary_key.rb', line 124

def quoted_primary_key
  @quoted_primary_key ||= connection.quote_column_name(primary_key)
end

#reset_primary_keyObject

:nodoc:



128
129
130
131
132
133
134
# File 'lib/active_record/attribute_methods/primary_key.rb', line 128

def reset_primary_key # :nodoc:
  if base_class?
    self.primary_key = get_primary_key(base_class.name)
  else
    self.primary_key = base_class.primary_key
  end
end