Module: Mongoid::Criteria::Findable

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

Instance Method Summary collapse

Instance Method Details

#execute_or_raise(ids, multi) ⇒ Document | Array<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:



18
19
20
21
22
# File 'build/mongoid-8.1/lib/mongoid/criteria/findable.rb', line 18

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

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

Note:

Each argument can be an individual id, an array of ids or a nested array. Each array will be flattened.

Find the matching document(s) in the criteria for the provided id(s).

Examples:

Find by an id.

criteria.find(BSON::ObjectId.new)

Find by multiple ids.

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

Parameters:

  • *args ([ Object | Array<Object> ]...)

    The id(s) to find.

Returns:



38
39
40
41
42
# File 'build/mongoid-8.1/lib/mongoid/criteria/findable.rb', line 38

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:



55
56
57
58
59
60
61
62
# File 'build/mongoid-8.1/lib/mongoid/criteria/findable.rb', line 55

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.



73
74
75
76
77
# File 'build/mongoid-8.1/lib/mongoid/criteria/findable.rb', line 73

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