Module: Mongoid::QueryCache

Defined in:
lib/mongoid/query_cache.rb

Overview

A cache of database queries on a per-request basis.

Since:

  • 4.0.0

Defined Under Namespace

Modules: Base, Collection, Document, View Classes: CachedCursor, Middleware

Class Method Summary collapse

Class Method Details

.cacheObject

Execute the block while using the query cache.

Examples:

Execute with the cache.

QueryCache.cache { collection.find }

Returns:

  • (Object)

    The result of the block.

Since:

  • 4.0.0



68
69
70
71
72
73
74
# File 'lib/mongoid/query_cache.rb', line 68

def cache
  enabled = QueryCache.enabled?
  QueryCache.enabled = true
  yield
ensure
  QueryCache.enabled = enabled
end

.cache_tableHash

Get the cached queries.

Examples:

Get the cached queries from the current thread.

QueryCache.cache_table

Returns:

  • (Hash)

    The hash of cached queries.

Since:

  • 4.0.0



20
21
22
# File 'lib/mongoid/query_cache.rb', line 20

def cache_table
  Thread.current["[mongoid]:query_cache"] ||= {}
end

.clear_cachenil

Clear the query cache.

Examples:

Clear the cache.

QueryCache.clear_cache

Returns:

  • (nil)

    Always nil.

Since:

  • 4.0.0



32
33
34
# File 'lib/mongoid/query_cache.rb', line 32

def clear_cache
  Thread.current["[mongoid]:query_cache"] = nil
end

.enabled=(value) ⇒ Object

Set whether the cache is enabled.

Examples:

Set if the cache is enabled.

QueryCache.enabled = true

Parameters:

  • value (true, false)

    The enabled value.

Since:

  • 4.0.0



44
45
46
# File 'lib/mongoid/query_cache.rb', line 44

def enabled=(value)
  Thread.current["[mongoid]:query_cache:enabled"] = value
end

.enabled?true, false

Is the query cache enabled on the current thread?

Examples:

Is the query cache enabled?

QueryCache.enabled?

Returns:

  • (true, false)

    If the cache is enabled.

Since:

  • 4.0.0



56
57
58
# File 'lib/mongoid/query_cache.rb', line 56

def enabled?
  !!Thread.current["[mongoid]:query_cache:enabled"]
end

.uncachedObject

Execute the block with the query cache disabled.

Examples:

Execute without the cache.

QueryCache.uncached { collection.find }

Returns:

  • (Object)

    The result of the block.

Since:

  • 4.0.0



82
83
84
85
86
87
88
# File 'lib/mongoid/query_cache.rb', line 82

def uncached
  enabled = QueryCache.enabled?
  QueryCache.enabled = false
  yield
ensure
  QueryCache.enabled = enabled
end