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
-
#query_cache ⇒ Object
readonly
Returns the value of attribute query_cache.
-
#query_cache_enabled ⇒ Object
readonly
Returns the value of attribute query_cache_enabled.
Class Method Summary collapse
Instance Method Summary collapse
-
#cache ⇒ Object
Enable the query cache within the block.
-
#clear_query_cache ⇒ Object
Clears the query cache.
- #disable_query_cache! ⇒ Object
- #enable_query_cache! ⇒ Object
- #initialize ⇒ Object
-
#select_all(arel, name = nil, binds = [], preparable: nil, async: false) ⇒ Object
:nodoc:.
-
#uncached ⇒ Object
Disable the query cache within the block.
Instance Attribute Details
#query_cache ⇒ Object (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_enabled ⇒ Object (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
#cache ⇒ Object
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_cache ⇒ Object
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 |
#initialize ⇒ Object
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 |
#uncached ⇒ Object
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 |