edge badge
Methods
A
C
D
I
M
N
P
S
T
Attributes
[RW] connection
[R] version
Class Public methods
new(conn)
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 7
def initialize(conn)
  @connection = conn

  @columns      = {}
  @columns_hash = {}
  @primary_keys = {}
  @data_sources = {}
end
Instance Public methods
add(table_name)

Add internal cache for table with table_name.

# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 39
def add(table_name)
  if data_source_exists?(table_name)
    primary_keys(table_name)
    columns(table_name)
    columns_hash(table_name)
  end
end
clear!()

Clears out internal caches

# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 67
def clear!
  @columns.clear
  @columns_hash.clear
  @primary_keys.clear
  @data_sources.clear
  @version = nil
end
clear_data_source_cache!(name)

Clear out internal caches for the data source name.

Also aliased as: clear_table_cache!
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 80
def clear_data_source_cache!(name)
  @columns.delete name
  @columns_hash.delete name
  @primary_keys.delete name
  @data_sources.delete name
end
clear_table_cache!(name)
columns(table_name)

Get the columns for a table

# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 54
def columns(table_name)
  @columns[table_name] ||= connection.columns(table_name)
end
columns_hash(table_name)

Get the columns for a table as a hash, key is the column name value is the column object.

# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 60
def columns_hash(table_name)
  @columns_hash[table_name] ||= Hash[columns(table_name).map { |col|
    [col.name, col]
  }]
end
data_source_exists?(name)

A cached lookup for table existence.

Also aliased as: table_exists?
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 29
def data_source_exists?(name)
  prepare_data_sources if @data_sources.empty?
  return @data_sources[name] if @data_sources.key? name

  @data_sources[name] = connection.data_source_exists?(name)
end
data_sources(name)
Also aliased as: tables
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 47
def data_sources(name)
  @data_sources[name]
end
initialize_dup(other)
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 16
def initialize_dup(other)
  super
  @columns      = @columns.dup
  @columns_hash = @columns_hash.dup
  @primary_keys = @primary_keys.dup
  @data_sources = @data_sources.dup
end
marshal_dump()
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 89
def marshal_dump
  # if we get current version during initialization, it happens stack over flow.
  @version = ActiveRecord::Migrator.current_version
  [@version, @columns, @columns_hash, @primary_keys, @data_sources]
end
marshal_load(array)
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 95
def marshal_load(array)
  @version, @columns, @columns_hash, @primary_keys, @data_sources = array
end
primary_keys(table_name)
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 24
def primary_keys(table_name)
  @primary_keys[table_name] ||= data_source_exists?(table_name) ? connection.primary_key(table_name) : nil
end
size()
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 75
def size
  [@columns, @columns_hash, @primary_keys, @data_sources].map(&:size).inject :+
end
table_exists?(name)
Alias for: data_source_exists?
tables(name)
Alias for: data_sources