Module: Mongoid::Criteria::Findable

Included in:
Mongoid::Criteria
Defined in:
build/mongoid-7.3/lib/mongoid/criteria/findable.rb

Instance Method Summary collapse

Instance Method Details

#execute_or_raise(ids, multi) ⇒ Document+

Execute the criteria or raise an error if no documents found.

Examples:

Execute or raise

criteria.execute_or_raise(id)

Parameters:

  • ids (Object)

    The arguments passed.

  • multi (true, false)

    Whether there arguments were a list.

Returns:

Raises:

Since:

  • 2.0.0



21
22
23
24
25
# File 'build/mongoid-7.3/lib/mongoid/criteria/findable.rb', line 21

def execute_or_raise(ids, multi)
  result = multiple_from_db(ids)
  check_for_missing_documents!(result, ids)
  multi ? result : result.first
end

#find(*args) ⇒ Array<Document>, Document

Find the matchind document(s) in the criteria for the provided ids.

Examples:

Find by an id.

criteria.find(BSON::ObjectId.new)

Find by multiple ids.

criteria.find([ BSON::ObjectId.new, BSON::ObjectId.new ])

Parameters:

Returns:

Since:

  • 1.0.0



40
41
42
43
44
# File 'build/mongoid-7.3/lib/mongoid/criteria/findable.rb', line 40

def find(*args)
  ids = args.__find_args__
  raise_invalid if ids.any?(&:nil?)
  for_ids(ids).execute_or_raise(ids, args.multi_arged?)
end

#for_ids(ids) ⇒ Criteria

Adds a criterion to the Criteria that specifies an id that must be matched.

Examples:

Add a single id criteria.

criteria.for_ids([ 1 ])

Add multiple id criteria.

criteria.for_ids([ 1, 2 ])

Parameters:

  • ids (Array)

    The array of ids.

Returns:



57
58
59
60
61
62
63
64
# File 'build/mongoid-7.3/lib/mongoid/criteria/findable.rb', line 57

def for_ids(ids)
  ids = mongoize_ids(ids)
  if ids.size > 1
    send(id_finder, { _id: { "$in" => ids }})
  else
    send(id_finder, { _id: ids.first })
  end
end

#multiple_from_db(ids) ⇒ Array<Document>

Get the documents from the identity map, and if not found hit the database.

Examples:

Get the documents from the map or criteria.

criteria.multiple_from_map_or_db(ids)

Parameters:

  • ids (Array<Object>)

    The searched ids.

Returns:

  • (Array<Document>)

    The found documents.



75
76
77
78
79
# File 'build/mongoid-7.3/lib/mongoid/criteria/findable.rb', line 75

def multiple_from_db(ids)
  return entries if embedded?
  ids = mongoize_ids(ids)
  ids.empty? ? [] : from_database(ids)
end