Class: Mongoid::Contextual::Mongo
- Inherits:
-
Object
- Object
- Mongoid::Contextual::Mongo
- Extended by:
- Forwardable
- Includes:
- Enumerable, Association::EagerLoadable, Atomic, Aggregable::Mongo, Queryable
- Defined in:
- lib/mongoid/contextual/mongo.rb
Constant Summary collapse
- OPTIONS =
Options constant.
[ :hint, :limit, :skip, :sort, :batch_size, :max_scan, :max_time_ms, :snapshot, :comment, :read, :cursor_type, :collation ].freeze
Constants included from Atomic
Instance Attribute Summary collapse
-
#view ⇒ Object
readonly
Returns the value of attribute view.
- #view The Mongo collection view.(TheMongocollectionview.) ⇒ Object readonly
Attributes included from Queryable
#collection, #collection The collection to query against., #criteria, #criteria The criteria for the context., #klass, #klass The klass for the criteria.
Instance Method Summary collapse
-
#cached? ⇒ true, false
Is the context cached?.
-
#count(options = {}, &block) ⇒ Integer
Get the number of documents matching the query.
-
#delete ⇒ nil
(also: #delete_all)
Delete all documents in the database that match the selector.
-
#destroy ⇒ nil
(also: #destroy_all)
Destroy all documents in the database that match the selector.
-
#distinct(field) ⇒ Array<Object>
Get the distinct values in the db for the provided field.
-
#each(&block) ⇒ Enumerator
Iterate over the context.
-
#estimated_count(options = {}) ⇒ Integer
Get the estimated number of documents matching the query.
-
#exists? ⇒ true, false
Do any documents exist for the context.
-
#explain ⇒ Hash
Run an explain on the criteria.
-
#find_first ⇒ Object
private
Return the first result without applying sort.
-
#find_one_and_delete ⇒ Document
Execute the find and modify command, used for MongoDB’s $findAndModify.
-
#find_one_and_replace(replacement, options = {}) ⇒ Document
Execute the find and modify command, used for MongoDB’s $findAndModify.
-
#find_one_and_update(update, options = {}) ⇒ Document
Execute the find and modify command, used for MongoDB’s $findAndModify.
-
#first(opts = {}) ⇒ Document
(also: #one)
Get the first document in the database for the criteria’s selector.
- #geo_near(coordinates) ⇒ GeoNear deprecated Deprecated.
-
#initialize(criteria) ⇒ Mongo
constructor
Create the new Mongo context.
-
#last(opts = {}) ⇒ Object
Get the last document in the database for the criteria’s selector.
-
#length ⇒ Integer
(also: #size)
Get’s the number of documents matching the query selector.
-
#limit(value) ⇒ Mongo
Limits the number of documents that are returned from the database.
-
#map(field = nil, &block) ⇒ Array
Invoke the block for each element of Contextual.
-
#map_reduce(map, reduce) ⇒ MapReduce
Initiate a map/reduce operation from the context.
-
#pluck(*fields) ⇒ Array<Object, Array>
Pluck the single field values from the database.
-
#skip(value) ⇒ Mongo
Skips the provided number of documents.
-
#sort(values = nil, &block) ⇒ Mongo
Sorts the documents by the provided spec.
-
#update(attributes = nil, opts = {}) ⇒ nil, false
Update the first matching document atomically.
-
#update_all(attributes = nil, opts = {}) ⇒ nil, false
Update all the matching documents atomically.
Methods included from Queryable
Methods included from Association::EagerLoadable
#eager_load, #eager_loadable?, #preload
Methods included from Atomic
#add_atomic_pull, #add_atomic_unset, #atomic_array_add_to_sets, #atomic_array_pulls, #atomic_array_pushes, #atomic_attribute_name, #atomic_delete_modifier, #atomic_insert_modifier, #atomic_path, #atomic_paths, #atomic_position, #atomic_pulls, #atomic_pushes, #atomic_sets, #atomic_unsets, #atomic_updates, #delayed_atomic_pulls, #delayed_atomic_sets, #delayed_atomic_unsets, #flag_as_destroyed, #flagged_destroys, #process_flagged_destroys
Methods included from Aggregable::Mongo
#aggregates, #avg, #max, #min, #sum
Constructor Details
#initialize(criteria) ⇒ Mongo
Create the new Mongo context. This delegates operations to the underlying driver.
364 365 366 367 368 369 370 |
# File 'lib/mongoid/contextual/mongo.rb', line 364 def initialize(criteria) @criteria, @klass, @cache = criteria, criteria.klass, criteria.[:cache] @collection = @klass.collection criteria.send(:merge_type_selection) @view = collection.find(criteria.selector, session: _session) end |
Instance Attribute Details
#view ⇒ Object (readonly)
Returns the value of attribute view.
39 40 41 |
# File 'lib/mongoid/contextual/mongo.rb', line 39 def view @view end |
#view The Mongo collection view.(TheMongocollectionview.) ⇒ Object (readonly)
39 |
# File 'lib/mongoid/contextual/mongo.rb', line 39 attr_reader :view |
Instance Method Details
#cached? ⇒ true, false
Is the context cached?
49 50 51 |
# File 'lib/mongoid/contextual/mongo.rb', line 49 def cached? !!@cache end |
#count(options = {}, &block) ⇒ Integer
Get the number of documents matching the query.
72 73 74 75 |
# File 'lib/mongoid/contextual/mongo.rb', line 72 def count( = {}, &block) return super(&block) if block_given? try_cache(:count) { view.count_documents() } end |
#delete ⇒ nil Also known as: delete_all
Delete all documents in the database that match the selector.
104 105 106 |
# File 'lib/mongoid/contextual/mongo.rb', line 104 def delete view.delete_many.deleted_count end |
#destroy ⇒ nil Also known as: destroy_all
Destroy all documents in the database that match the selector.
117 118 119 120 121 122 123 |
# File 'lib/mongoid/contextual/mongo.rb', line 117 def destroy each.inject(0) do |count, doc| doc.destroy count += 1 if acknowledged_write? count end end |
#distinct(field) ⇒ Array<Object>
Get the distinct values in the db for the provided field.
136 137 138 139 140 |
# File 'lib/mongoid/contextual/mongo.rb', line 136 def distinct(field) view.distinct(klass.database_field_name(field)).map do |value| value.class.demongoize(value) end end |
#each(&block) ⇒ Enumerator
Iterate over the context. If provided a block, yield to a Mongoid document for each, otherwise return an enum.
153 154 155 156 157 158 159 160 161 162 163 |
# File 'lib/mongoid/contextual/mongo.rb', line 153 def each(&block) if block_given? documents_for_iteration.each do |doc| yield_document(doc, &block) end @cache_loaded = true self else to_enum end end |
#estimated_count(options = {}) ⇒ Integer
Get the estimated number of documents matching the query.
Unlike count, estimated_count does not take a block because it is not traditionally defined (with a block) on Enumarable like count is.
89 90 91 92 93 94 |
# File 'lib/mongoid/contextual/mongo.rb', line 89 def estimated_count( = {}) unless self.criteria.selector.empty? raise Mongoid::Errors::InvalidEstimatedCountCriteria.new(self.klass) end try_cache(:estimated_count) { view.estimated_document_count() } end |
#exists? ⇒ true, false
We don’t use count here since Mongo does not use counted b-tree indexes, unless a count is already cached then that is used to determine the value.
Do any documents exist for the context.
177 178 179 180 181 182 183 184 |
# File 'lib/mongoid/contextual/mongo.rb', line 177 def exists? return !documents.empty? if cached? && cache_loaded? return @count > 0 if instance_variable_defined?(:@count) try_cache(:exists) do !!(view.projection(_id: 1).limit(1).first) end end |
#explain ⇒ Hash
Run an explain on the criteria.
194 195 196 |
# File 'lib/mongoid/contextual/mongo.rb', line 194 def explain view.explain end |
#find_first ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Return the first result without applying sort
299 300 301 302 303 304 305 |
# File 'lib/mongoid/contextual/mongo.rb', line 299 def find_first return documents.first if cached? && cache_loaded? if raw_doc = view.first doc = Factory.from_db(klass, raw_doc, criteria) eager_load([doc]).first end end |
#find_one_and_delete ⇒ Document
Execute the find and modify command, used for MongoDB’s $findAndModify. This deletes the found document.
251 252 253 254 255 |
# File 'lib/mongoid/contextual/mongo.rb', line 251 def find_one_and_delete if doc = view.find_one_and_delete Factory.from_db(klass, doc) end end |
#find_one_and_replace(replacement, options = {}) ⇒ Document
Execute the find and modify command, used for MongoDB’s $findAndModify.
236 237 238 239 240 |
# File 'lib/mongoid/contextual/mongo.rb', line 236 def find_one_and_replace(replacement, = {}) if doc = view.find_one_and_replace(replacement, ) Factory.from_db(klass, doc) end end |
#find_one_and_update(update, options = {}) ⇒ Document
Execute the find and modify command, used for MongoDB’s $findAndModify.
214 215 216 217 218 |
# File 'lib/mongoid/contextual/mongo.rb', line 214 def find_one_and_update(update, = {}) if doc = view.find_one_and_update(update, ) Factory.from_db(klass, doc) end end |
#first(opts = {}) ⇒ Document Also known as: one
Automatically adding a sort on _id when no other sort is defined on the criteria has the potential to cause bad performance issues. If you experience unexpected poor performance when using #first or #last and have no sort defined on the criteria, use the option { id_sort: :none }. Be aware that #first/#last won’t guarantee order in this case.
Get the first document in the database for the criteria’s selector.
276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 |
# File 'lib/mongoid/contextual/mongo.rb', line 276 def first(opts = {}) return documents.first if cached? && cache_loaded? try_cache(:first) do if sort = view.sort || ({ _id: 1 } unless opts[:id_sort] == :none) if raw_doc = view.sort(sort).limit(1).first doc = Factory.from_db(klass, raw_doc, criteria) eager_load([doc]).first end else if raw_doc = view.limit(1).first doc = Factory.from_db(klass, raw_doc, criteria) eager_load([doc]).first end end end end |
#geo_near(coordinates) ⇒ GeoNear
Execute a $geoNear command against the database.
328 329 330 |
# File 'lib/mongoid/contextual/mongo.rb', line 328 def geo_near(coordinates) GeoNear.new(collection, criteria, coordinates) end |
#last(opts = {}) ⇒ Object
Automatically adding a sort on _id when no other sort is defined on the criteria has the potential to cause bad performance issues. If you experience unexpected poor performance when using #first or #last and have no sort defined on the criteria, use the option { id_sort: :none }. Be aware that #first/#last won’t guarantee order in this case.
Get the last document in the database for the criteria’s selector.
391 392 393 394 395 396 397 398 399 400 |
# File 'lib/mongoid/contextual/mongo.rb', line 391 def last(opts = {}) try_cache(:last) do with_inverse_sorting(opts) do if raw_doc = view.limit(1).first doc = Factory.from_db(klass, raw_doc, criteria) eager_load([doc]).first end end end end |
#length ⇒ Integer Also known as: size
Get’s the number of documents matching the query selector.
410 411 412 |
# File 'lib/mongoid/contextual/mongo.rb', line 410 def length @length ||= self.count end |
#limit(value) ⇒ Mongo
Limits the number of documents that are returned from the database.
425 426 427 |
# File 'lib/mongoid/contextual/mongo.rb', line 425 def limit(value) @view = view.limit(value) and self end |
#map(field = nil, &block) ⇒ Array
Invoke the block for each element of Contextual. Create a new array containing the values returned by the block.
If the symbol field name is passed instead of the block, additional optimizations would be used.
347 348 349 350 351 352 353 |
# File 'lib/mongoid/contextual/mongo.rb', line 347 def map(field = nil, &block) if block_given? super(&block) else criteria.pluck(field) end end |
#map_reduce(map, reduce) ⇒ MapReduce
Initiate a map/reduce operation from the context.
440 441 442 |
# File 'lib/mongoid/contextual/mongo.rb', line 440 def map_reduce(map, reduce) MapReduce.new(collection, criteria, map, reduce) end |
#pluck(*fields) ⇒ Array<Object, Array>
This method will return the raw db values - it performs no custom serialization.
Pluck the single field values from the database. Will return duplicates if they exist and only works for top level fields.
458 459 460 461 462 463 464 465 466 467 468 469 470 |
# File 'lib/mongoid/contextual/mongo.rb', line 458 def pluck(*fields) normalized_select = fields.inject({}) do |hash, f| hash[klass.database_field_name(f)] = 1 hash end view.projection(normalized_select).reduce([]) do |plucked, doc| values = normalized_select.keys.map do |n| n =~ /\./ ? doc[n.partition('.')[0]] : doc[n] end plucked << (values.size == 1 ? values.first : values) end end |
#skip(value) ⇒ Mongo
Skips the provided number of documents.
482 483 484 |
# File 'lib/mongoid/contextual/mongo.rb', line 482 def skip(value) @view = view.skip(value) and self end |
#sort(values = nil, &block) ⇒ Mongo
Sorts the documents by the provided spec.
497 498 499 500 501 502 503 504 505 506 |
# File 'lib/mongoid/contextual/mongo.rb', line 497 def sort(values = nil, &block) if block_given? super(&block) else # update the criteria @criteria = criteria.order_by(values) apply_option(:sort) self end end |
#update(attributes = nil, opts = {}) ⇒ nil, false
Update the first matching document atomically.
522 523 524 |
# File 'lib/mongoid/contextual/mongo.rb', line 522 def update(attributes = nil, opts = {}) update_documents(attributes, :update_one, opts) end |
#update_all(attributes = nil, opts = {}) ⇒ nil, false
Update all the matching documents atomically.
540 541 542 |
# File 'lib/mongoid/contextual/mongo.rb', line 540 def update_all(attributes = nil, opts = {}) update_documents(attributes, :update_many, opts) end |