Active Record Connection Adapters Schema Cache
- A
- C
- D
- E
- I
- L
- M
- N
- P
- S
Attributes
| [RW] | connection | |
| [R] | version |
Class Public methods
load_from(filename) Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 9 def self.load_from(filename) return unless File.file?(filename) read(filename) do |file| if filename.include?(".dump") Marshal.load(file) else if YAML.respond_to?(:unsafe_load) YAML.unsafe_load(file) else YAML.load(file) end end end end
new(conn) Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 39 def initialize(conn) @connection = conn @columns = {} @columns_hash = {} @primary_keys = {} @data_sources = {} @indexes = {} end
Instance Public methods
add(table_name) Link
Add internal cache for table with table_name.
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 101 def add(table_name) if data_source_exists?(table_name) primary_keys(table_name) columns(table_name) columns_hash(table_name) indexes(table_name) end end
clear!() Link
Clears out internal caches
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 153 def clear! @columns.clear @columns_hash.clear @primary_keys.clear @data_sources.clear @indexes.clear @version = nil @database_version = nil end
clear_data_source_cache!(name) Link
Clear out internal caches for the data source name.
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 168 def clear_data_source_cache!(name) @columns.delete name @columns_hash.delete name @primary_keys.delete name @data_sources.delete name @indexes.delete name end
columns(table_name) Link
Get the columns for a table
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 115 def columns(table_name) if ignored_table?(table_name) raise ActiveRecord::StatementInvalid, "Table '#{table_name}' doesn't exist" end @columns.fetch(table_name) do @columns[deep_deduplicate(table_name)] = deep_deduplicate(connection.columns(table_name)) end end
columns_hash(table_name) Link
Get the columns for a table as a hash, key is the column name value is the column object.
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 127 def columns_hash(table_name) @columns_hash.fetch(table_name) do @columns_hash[deep_deduplicate(table_name)] = columns(table_name).index_by(&:name).freeze end end
columns_hash?(table_name) Link
Checks whether the columns hash is already cached for a table.
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 134 def columns_hash?(table_name) @columns_hash.key?(table_name) end
data_source_exists?(name) Link
A cached lookup for table existence.
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 92 def data_source_exists?(name) return if ignored_table?(name) prepare_data_sources if @data_sources.empty? return @data_sources[name] if @data_sources.key? name @data_sources[deep_deduplicate(name)] = connection.data_source_exists?(name) end
data_sources(name) Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 110 def data_sources(name) @data_sources[name] end
dump_to(filename) Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 176 def dump_to(filename) clear! tables_to_cache.each { |table| add(table) } open(filename) { |f| if filename.include?(".dump") f.write(Marshal.dump(self)) else f.write(YAML.dump(self)) end } end
encode_with(coder) Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 58 def encode_with(coder) reset_version! coder["columns"] = @columns coder["primary_keys"] = @primary_keys coder["data_sources"] = @data_sources coder["indexes"] = @indexes coder["version"] = @version coder["database_version"] = database_version end
indexes(table_name) Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 138 def indexes(table_name) @indexes.fetch(table_name) do if data_source_exists?(table_name) @indexes[deep_deduplicate(table_name)] = deep_deduplicate(connection.indexes(table_name)) else [] end end end
init_with(coder) Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 69 def init_with(coder) @columns = coder["columns"] @columns_hash = coder["columns_hash"] @primary_keys = coder["primary_keys"] @data_sources = coder["data_sources"] @indexes = coder["indexes"] || {} @version = coder["version"] @database_version = coder["database_version"] unless coder["deduplicated"] derive_columns_hash_and_deduplicate_values end end
initialize_dup(other) Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 49 def initialize_dup(other) super @columns = @columns.dup @columns_hash = @columns_hash.dup @primary_keys = @primary_keys.dup @data_sources = @data_sources.dup @indexes = @indexes.dup end
marshal_dump() Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 188 def marshal_dump reset_version! [@version, @columns, {}, @primary_keys, @data_sources, @indexes, database_version] end
marshal_load(array) Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 194 def marshal_load(array) @version, @columns, _columns_hash, @primary_keys, @data_sources, @indexes, @database_version = array @indexes ||= {} derive_columns_hash_and_deduplicate_values end
primary_keys(table_name) Link
Source: show
# File activerecord/lib/active_record/connection_adapters/schema_cache.rb, line 83 def primary_keys(table_name) @primary_keys.fetch(table_name) do if data_source_exists?(table_name) @primary_keys[deep_deduplicate(table_name)] = deep_deduplicate(connection.primary_key(table_name)) end end end