Class: Mongoid::Contextual::MapReduce
- Inherits:
-
Object
- Object
- Mongoid::Contextual::MapReduce
- Extended by:
- Forwardable
- Includes:
- Enumerable, Command
- Defined in:
- lib/mongoid/contextual/map_reduce.rb
Overview
Represents a mapReduce database command instruction.
Instance Attribute Summary
Attributes included from Command
#collection, #collection The collection to query against., #criteria, #criteria The criteria for the context.
Instance Method Summary collapse
-
#command ⇒ Hash
Returns the selector of the command spec.
-
#counts ⇒ Hash
Get all the counts returned by the map/reduce.
-
#each ⇒ Enumerator
Iterates over each of the documents in the map/reduce, excluding the extra information that was passed back from the database.
-
#emitted ⇒ Integer
Get the number of documents emitted by the map/reduce.
-
#finalize(function) ⇒ MapReduce
Provide a finalize js function for the map/reduce.
-
#initialize(collection, criteria, map, reduce) ⇒ MapReduce
constructor
Initialize the new map/reduce directive.
-
#input ⇒ Integer
Get the number of documents that were input into the map/reduce.
-
#inspect ⇒ String
Get a pretty string representation of the map/reduce, including the criteria, map, reduce, finalize, and out option.
-
#js_mode ⇒ MapReduce
Sets the map/reduce to use jsMode.
-
#out(location) ⇒ MapReduce
Specifies where the map/reduce output is to be stored.
-
#output ⇒ Integer
Get the number of documents output by the map/reduce.
-
#raw ⇒ Hash
(also: #results, #execute)
Get the raw output from the map/reduce operation.
-
#reduced ⇒ Integer
Get the number of documents reduced by the map/reduce.
-
#scope(object) ⇒ MapReduce
Adds a javascript object to the global scope of the map/reduce.
-
#time ⇒ Float
Get the execution time of the map/reduce.
Methods included from Command
Constructor Details
#initialize(collection, criteria, map, reduce) ⇒ MapReduce
Initialize the new map/reduce directive.
77 78 79 80 81 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 77 def initialize(collection, criteria, map, reduce) @collection = collection @criteria = criteria @map_reduce = @criteria.view.map_reduce(map, reduce) end |
Instance Method Details
#command ⇒ Hash
Returns the selector of the command spec.
221 222 223 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 221 def command @map_reduce.send(:map_reduce_spec)[:selector] end |
#counts ⇒ Hash
Get all the counts returned by the map/reduce.
22 23 24 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 22 def counts results["counts"] end |
#each ⇒ Enumerator
Iterates over each of the documents in the map/reduce, excluding the extra information that was passed back from the database.
35 36 37 38 39 40 41 42 43 44 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 35 def each validate_out! if block_given? @map_reduce.each do |doc| yield doc end else @map_reduce.to_enum end end |
#emitted ⇒ Integer
Get the number of documents emitted by the map/reduce.
52 53 54 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 52 def emitted counts["emit"] end |
#finalize(function) ⇒ MapReduce
Provide a finalize js function for the map/reduce.
64 65 66 67 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 64 def finalize(function) @map_reduce = @map_reduce.finalize(function) self end |
#input ⇒ Integer
Get the number of documents that were input into the map/reduce.
89 90 91 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 89 def input counts["input"] end |
#inspect ⇒ String
Get a pretty string representation of the map/reduce, including the criteria, map, reduce, finalize, and out option.
207 208 209 210 211 212 213 214 215 216 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 207 def inspect %Q{#<Mongoid::Contextual::MapReduce selector: #{criteria.selector.inspect} class: #{criteria.klass} map: #{command[:map]} reduce: #{command[:reduce]} finalize: #{command[:finalize]} out: #{command[:out].inspect}> } end |
#js_mode ⇒ MapReduce
Sets the map/reduce to use jsMode.
99 100 101 102 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 99 def js_mode @map_reduce = @map_reduce.js_mode(true) self end |
#out(location) ⇒ MapReduce
Specifies where the map/reduce output is to be stored. Please see MongoDB documentation for supported map reduce options.
125 126 127 128 129 130 131 132 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 125 def out(location) normalized = location.dup normalized.transform_values! do |value| value.is_a?(::Symbol) ? value.to_s : value end @map_reduce = @map_reduce.out(normalized) self end |
#output ⇒ Integer
Get the number of documents output by the map/reduce.
140 141 142 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 140 def output counts["output"] end |
#raw ⇒ Hash Also known as: results, execute
Get the raw output from the map/reduce operation.
150 151 152 153 154 155 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 150 def raw validate_out! cmd = command opts = { read: criteria..fetch(:read) } if criteria.[:read] @map_reduce.database.command(cmd, (opts || {}).merge(session: _session)).first end |
#reduced ⇒ Integer
Get the number of documents reduced by the map/reduce.
173 174 175 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 173 def reduced counts["reduce"] end |
#scope(object) ⇒ MapReduce
Adds a javascript object to the global scope of the map/reduce.
185 186 187 188 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 185 def scope(object) @map_reduce = @map_reduce.scope(object) self end |
#time ⇒ Float
Get the execution time of the map/reduce.
196 197 198 |
# File 'lib/mongoid/contextual/map_reduce.rb', line 196 def time results["timeMillis"] end |