Module: ActiveRecord::ConnectionAdapters::QueryCache

Included in:
AbstractAdapter
Defined in:
lib/active_record/connection_adapters/abstract/query_cache.rb

Defined Under Namespace

Modules: ConnectionPoolConfiguration

Constant Summary collapse

DEFAULT_SIZE =

:nodoc:

100

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#query_cacheObject (readonly)

Returns the value of attribute query_cache.



53
54
55
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 53

def query_cache
  @query_cache
end

#query_cache_enabledObject (readonly)

Returns the value of attribute query_cache_enabled.



53
54
55
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 53

def query_cache_enabled
  @query_cache_enabled
end

Class Method Details

.dirties_query_cache(base, *method_names) ⇒ Object



20
21
22
23
24
25
26
27
28
29
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 20

def dirties_query_cache(base, *method_names)
  method_names.each do |method_name|
    base.class_eval <<-end_code, __FILE__, __LINE__ + 1
      def #{method_name}(...)
        ActiveRecord::Base.clear_query_caches_for_current_thread
        super
      end
    end_code
  end
end

.included(base) ⇒ Object

:nodoc:



11
12
13
14
15
16
17
18
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 11

def included(base) # :nodoc:
  dirties_query_cache base, :exec_query, :execute, :create, :insert, :update, :delete, :truncate,
    :truncate_tables, :rollback_to_savepoint, :rollback_db_transaction, :restart_db_transaction,
    :exec_insert_all

  base.set_callback :checkout, :after, :configure_query_cache!
  base.set_callback :checkin, :after, :disable_query_cache!
end

Instance Method Details

#cacheObject

Enable the query cache within the block.



63
64
65
66
67
68
69
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 63

def cache
  old, @query_cache_enabled = @query_cache_enabled, true
  yield
ensure
  @query_cache_enabled = old
  clear_query_cache unless @query_cache_enabled
end

#clear_query_cacheObject

Clears the query cache.

One reason you may wish to call this method explicitly is between queries that ask the database to randomize results. Otherwise the cache would see the same SQL query and repeatedly return the same result each time, silently undermining the randomness you were expecting.



94
95
96
97
98
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 94

def clear_query_cache
  @lock.synchronize do
    @query_cache.clear
  end
end

#disable_query_cache!Object



75
76
77
78
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 75

def disable_query_cache!
  @query_cache_enabled = false
  clear_query_cache
end

#enable_query_cache!Object



71
72
73
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 71

def enable_query_cache!
  @query_cache_enabled = true
end

#initializeObject



55
56
57
58
59
60
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 55

def initialize(*)
  super
  @query_cache         = {}
  @query_cache_enabled = false
  @query_cache_max_size = nil
end

#select_all(arel, name = nil, binds = [], preparable: nil, async: false) ⇒ Object

:nodoc:



100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 100

def select_all(arel, name = nil, binds = [], preparable: nil, async: false) # :nodoc:
  arel = arel_from_relation(arel)

  # If arel is locked this is a SELECT ... FOR UPDATE or somesuch.
  # Such queries should not be cached.
  if @query_cache_enabled && !(arel.respond_to?(:locked) && arel.locked)
    sql, binds, preparable = to_sql_and_binds(arel, binds, preparable)

    if async
      result = lookup_sql_cache(sql, name, binds) || super(sql, name, binds, preparable: preparable, async: async)
      FutureResult::Complete.new(result)
    else
      cache_sql(sql, name, binds) { super(sql, name, binds, preparable: preparable, async: async) }
    end
  else
    super
  end
end

#uncachedObject

Disable the query cache within the block.



81
82
83
84
85
86
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 81

def uncached
  old, @query_cache_enabled = @query_cache_enabled, false
  yield
ensure
  @query_cache_enabled = old
end