Module: Mongoid::Findable
- Extended by:
- Forwardable
- Defined in:
- lib/mongoid/findable.rb
Overview
This module defines the finder methods that hang off the document at the class level.
Instance Method Summary collapse
-
#empty? ⇒ true, false
Returns true if count is zero.
-
#estimated_count ⇒ Integer
Returns an estimated count of records in the database.
-
#exists? ⇒ true, false
Returns true if there are on document in database based on the provided arguments.
-
#find(*args) ⇒ Document | Array<Document> | nil
Finds a
Document
or multiple documents by their _id values. -
#find_by(attrs = {}) {|result| ... } ⇒ Document?
Find the first
Document
given the conditions. -
#find_by!(attrs = {}) {|result| ... } ⇒ Document
Find the first
Document
given the conditions, or raises Mongoid::Errors::DocumentNotFound. -
#first(limit_or_opts = nil) ⇒ Document
(also: #one)
Find the first
Document
given the conditions. -
#last(limit_or_opts = nil) ⇒ Document
Find the last
Document
given the conditions.
Instance Method Details
#empty? ⇒ true, false
Returns true if count is zero
79 80 81 |
# File 'lib/mongoid/findable.rb', line 79 def empty? count == 0 end |
#estimated_count ⇒ Integer
Returns an estimated count of records in the database.
69 70 71 |
# File 'lib/mongoid/findable.rb', line 69 def estimated_count with_default_scope.estimated_count end |
#exists? ⇒ true, false
Returns true if there are on document in database based on the provided arguments.
90 91 92 |
# File 'lib/mongoid/findable.rb', line 90 def exists? with_default_scope.exists? end |
#find(*args) ⇒ Document | Array<Document> | nil
Finds a Document
or multiple documents by their _id values.
If a single non-Array argument is given, this argument is interpreted as the _id value of a document to find. If there is a matching document in the database, this document is returned; otherwise, if the raise_not_found_error
Mongoid configuration option is truthy (which is the default), Errors::DocumentNotFound
is raised, and if raise_not_found_error
is falsy, find
returns nil
.
If multiple arguments are given, or an Array argument is given, the array is flattened and each array element is interpreted as the _id value of the document to find. Mongoid then attempts to retrieve all documents with the provided _id values. The return value is an array of found documents. Each document appears one time in the returned array, even if its _id is given multiple times in the argument to find
. If the raise_not_found_error
Mongoid configuration option is truthy, Errors::DocumentNotFound
exception is raised if any of the specified _ids were not found in the database. If the +raise_not_found_error
Mongoid configuration option is falsy, only those documents which are found are returned; if no documents are found, the return value is an empty array.
Note that MongoDB does not allow the _id field to be an array.
The argument undergoes customary Mongoid type conversions based on the type declared for the _id field. By default the _id field is a BSON::ObjectId
; this allows strings to be passed to find
and the strings will be transparently converted to BSON::ObjectId
instances during query construction.
The find
method takes into account the default scope defined on the model class, if any.
134 135 136 |
# File 'lib/mongoid/findable.rb', line 134 def find(*args) with_default_scope.find(*args) end |
#find_by(attrs = {}) {|result| ... } ⇒ Document?
Find the first Document
given the conditions. If a matching Document is not found and Mongoid.raise_not_found_error is true it raises Mongoid::Errors::DocumentNotFound, return null nil elsewise.
and Mongoid.raise_not_found_error is true.
152 153 154 155 156 157 158 159 |
# File 'lib/mongoid/findable.rb', line 152 def find_by(attrs = {}) result = where(attrs).find_first if result.nil? && Mongoid.raise_not_found_error raise(Errors::DocumentNotFound.new(self, attrs)) end yield(result) if result && block_given? result end |
#find_by!(attrs = {}) {|result| ... } ⇒ Document
Find the first Document
given the conditions, or raises Mongoid::Errors::DocumentNotFound
173 174 175 176 177 178 |
# File 'lib/mongoid/findable.rb', line 173 def find_by!(attrs = {}) result = where(attrs).find_first raise(Errors::DocumentNotFound.new(self, attrs)) unless result yield(result) if result && block_given? result end |
#first(limit_or_opts = nil) ⇒ Document Also known as: one
Find the first Document
given the conditions.
192 193 194 |
# File 'lib/mongoid/findable.rb', line 192 def first(limit_or_opts = nil) with_default_scope.first(limit_or_opts) end |
#last(limit_or_opts = nil) ⇒ Document
Find the last Document
given the conditions.
209 210 211 |
# File 'lib/mongoid/findable.rb', line 209 def last(limit_or_opts = nil) with_default_scope.last(limit_or_opts) end |