Module: ActiveRecord::ConnectionAdapters::QueryCache
- Included in:
- AbstractAdapter
- Defined in:
- lib/active_record/connection_adapters/abstract/query_cache.rb
Defined Under Namespace
Modules: ConnectionPoolConfiguration
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) ⇒ Object
-
#uncached ⇒ Object
Disable the query cache within the block.
Instance Attribute Details
#query_cache ⇒ Object (readonly)
Returns the value of attribute query_cache.
49 50 51 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 49 def query_cache @query_cache end |
#query_cache_enabled ⇒ Object (readonly)
Returns the value of attribute query_cache_enabled.
49 50 51 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 49 def query_cache_enabled @query_cache_enabled end |
Class Method Details
.dirties_query_cache(base, *method_names) ⇒ Object
16 17 18 19 20 21 22 23 24 25 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 16 def dirties_query_cache(base, *method_names) method_names.each do |method_name| base.class_eval <<-end_code, __FILE__, __LINE__ + 1 def #{method_name}(*) clear_query_cache if @query_cache_enabled super end end_code end end |
.included(base) ⇒ Object
:nodoc:
9 10 11 12 13 14 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 9 def included(base) #:nodoc: dirties_query_cache base, :insert, :update, :delete, :rollback_to_savepoint, :rollback_db_transaction 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.
58 59 60 61 62 63 64 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 58 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.
89 90 91 92 93 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 89 def clear_query_cache @lock.synchronize do @query_cache.clear end end |
#disable_query_cache! ⇒ Object
70 71 72 73 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 70 def disable_query_cache! @query_cache_enabled = false clear_query_cache end |
#enable_query_cache! ⇒ Object
66 67 68 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 66 def enable_query_cache! @query_cache_enabled = true end |
#initialize ⇒ Object
51 52 53 54 55 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 51 def initialize(*) super @query_cache = Hash.new { |h, sql| h[sql] = {} } @query_cache_enabled = false end |
#select_all(arel, name = nil, binds = [], preparable: nil) ⇒ Object
95 96 97 98 99 100 101 102 103 104 105 106 107 108 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 95 def select_all(arel, name = nil, binds = [], preparable: nil) if @query_cache_enabled && !locked?(arel) arel = arel_from_relation(arel) sql, binds = to_sql_and_binds(arel, binds) if preparable.nil? preparable = prepared_statements ? visitor.preparable : false end cache_sql(sql, name, binds) { super(sql, name, binds, preparable: preparable) } else super end end |
#uncached ⇒ Object
Disable the query cache within the block.
76 77 78 79 80 81 |
# File 'lib/active_record/connection_adapters/abstract/query_cache.rb', line 76 def uncached old, @query_cache_enabled = @query_cache_enabled, false yield ensure @query_cache_enabled = old end |