diff options
Diffstat (limited to 'activerecord')
-rwxr-xr-x | activerecord/lib/active_record.rb | 2 | ||||
-rw-r--r-- | activerecord/lib/active_record/query_cache.rb | 64 |
2 files changed, 66 insertions, 0 deletions
diff --git a/activerecord/lib/active_record.rb b/activerecord/lib/active_record.rb index 02d5968be7..a6169272a1 100755 --- a/activerecord/lib/active_record.rb +++ b/activerecord/lib/active_record.rb @@ -67,3 +67,5 @@ require 'active_record/connection_adapters/sqlite_adapter' require 'active_record/connection_adapters/sqlserver_adapter' require 'active_record/connection_adapters/db2_adapter' require 'active_record/connection_adapters/oci_adapter' + +require 'active_record/query_cache' diff --git a/activerecord/lib/active_record/query_cache.rb b/activerecord/lib/active_record/query_cache.rb new file mode 100644 index 0000000000..368b08e506 --- /dev/null +++ b/activerecord/lib/active_record/query_cache.rb @@ -0,0 +1,64 @@ +module ActiveRecord + class QueryCache + def initialize(connection) + @connection = connection + @query_cache = {} + end + + def clear_query_cache + @query_cache = {} + end + + def select_all(sql, name = nil) + @query_cache[sql] ||= @connection.select_all(sql, name) + end + + def select_one(sql, name = nil) + @query_cache[sql] ||= @connection.select_one(sql, name) + end + + def columns(table_name, name = nil) + @query_cache["SHOW FIELDS FROM #{table_name}"] ||= @connection.columns(table_name, name) + end + + def insert(sql, name = nil, pk = nil, id_value = nil) + clear_query_cache + @connection.insert(sql, name, pk, id_value) + end + + def update(sql, name = nil) + clear_query_cache + @connection.update(sql, name) + end + + def delete(sql, name = nil) + clear_query_cache + @connection.delete(sql, name) + end + + private + def method_missing(method, *arguments) + @connection.send(method, *arguments) + end + end + + class Base + # Set the connection for the class with caching on + def self.connection=(spec) + raise ConnectionNotEstablished unless spec + + conn = spec.config[:query_cache] ? + QueryCache.new(self.send(spec.adapter_method, spec.config)) : + self.send(spec.adapter_method, spec.config) + + Thread.current['active_connections'] ||= {} + Thread.current['active_connections'][self] = conn + end + end + + class AbstractAdapter + # Stub method to be able to treat the connection the same whether the query cache has been turned on or not + def clear_query_cache + end + end +end |