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
-
#count ⇒ Integer
Returns a count of records in the database.
-
#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 ⇒ Document
(also: #one)
Find the first
Document
given the conditions. -
#last ⇒ Document
Find the last
Document
given the conditions.
Instance Method Details
#count ⇒ Integer
Returns a count of records in the database. If you want to specify conditions use where.
56 57 58 |
# File 'lib/mongoid/findable.rb', line 56 def count with_default_scope.count end |
#empty? ⇒ true, false
Returns true if count is zero
76 77 78 |
# File 'lib/mongoid/findable.rb', line 76 def empty? count == 0 end |
#estimated_count ⇒ Integer
Returns an estimated count of records in the database.
66 67 68 |
# File 'lib/mongoid/findable.rb', line 66 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.
87 88 89 |
# File 'lib/mongoid/findable.rb', line 87 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.
131 132 133 |
# File 'lib/mongoid/findable.rb', line 131 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.
149 150 151 152 153 154 155 156 |
# File 'lib/mongoid/findable.rb', line 149 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
170 171 172 173 174 175 |
# File 'lib/mongoid/findable.rb', line 170 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 ⇒ Document Also known as: one
Find the first Document
given the conditions.
183 184 185 |
# File 'lib/mongoid/findable.rb', line 183 def first with_default_scope.first end |
#last ⇒ Document
Find the last Document
given the conditions.
194 195 196 |
# File 'lib/mongoid/findable.rb', line 194 def last with_default_scope.last end |