blob: b14b37ce89dd265e92c2df5b15263884edcc0b2d (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
module ActiveRecord
module ConnectionAdapters
class SchemaCache
attr_reader :columns, :columns_hash, :primary_keys, :tables
attr_reader :column_defaults
attr_reader :connection
def initialize(conn)
@connection = conn
@tables = {}
@columns = Hash.new do |h, table_name|
h[table_name] =
# Fetch a list of columns
conn.columns(table_name, "#{table_name} Columns").tap do |cs|
# set primary key information
cs.each do |column|
column.primary = column.name == primary_keys[table_name]
end
end
end
@columns_hash = Hash.new do |h, table_name|
h[table_name] = Hash[columns[table_name].map { |col|
[col.name, col]
}]
end
@column_defaults = Hash.new do |h, table_name|
h[table_name] = Hash[columns[table_name].map { |col|
[col.name, col.default]
}]
end
@primary_keys = Hash.new do |h, table_name|
h[table_name] = table_exists?(table_name) ?
conn.primary_key(table_name) : 'id'
end
end
# A cached lookup for table existence.
def table_exists?(name)
return @tables[name] if @tables.key? name
connection.tables.each { |table| @tables[table] = true }
@tables[name] = connection.table_exists?(name) if !@tables.key?(name)
@tables[name]
end
# Clears out internal caches:
#
# * columns
# * columns_hash
# * tables
def clear!
@columns.clear
@columns_hash.clear
@column_defaults.clear
@tables.clear
end
# Clear out internal caches for table with +table_name+.
def clear_table_cache!(table_name)
@columns.delete table_name
@columns_hash.delete table_name
@column_defaults.delete table_name
@primary_keys.delete table_name
end
end
end
end
|