Definition
$arrayElemAtReturns the element at the specified array index.
Compatibility
You can use $arrayElemAt for deployments hosted in the following environments:
- MongoDB Atlas: The fully managed service for MongoDB deployments in the cloud
- MongoDB Enterprise: The subscription-based, self-managed version of MongoDB
- MongoDB Community: The source-available, free-to-use, and self-managed version of MongoDB
Syntax
$arrayElemAt has the following syntax:
{ $arrayElemAt: [ <array>, <idx> ] }The <array> expression can be any valid expression that resolves to an array.
The <idx> expression can be any valid expression that resolves to an integer.
For more information on expressions, see Expressions.
Behavior
If the
<idx>expression resolves to zero or a positive integer,$arrayElemAtreturns the element at theidxposition, counting from the start of the array.If the
<idx>expression resolves to a negative integer,$arrayElemAtreturns the element at theidxposition, counting from the end of the array.- If
idxexceeds the array bounds,$arrayElemAtdoes not return a result. - If the
<array>expression resolves to an undefined array,$arrayElemAtreturnsnull.
| Example | Results |
|---|---|
|
|
|
|
| |
|
|
Example
A collection named users contains the following documents:
db.users.insertMany( [
{ _id: 1, name: "dave123", favorites: [ "chocolate", "cake", "butter", "apples" ] },
{ _id: 2, name: "li", favorites: [ "apples", "pudding", "pie" ] },
{ _id: 3, name: "ahn", favorites: [ "pears", "pecans", "chocolate", "cherries" ] },
{ _id: 4, name: "ty", favorites: [ "ice cream" ] }
] )The following example returns the first and last element in the favorites array:
db.users.aggregate([
{
$project:
{
name: 1,
first: { $arrayElemAt: [ "$favorites", 0 ] },
last: { $arrayElemAt: [ "$favorites", -1 ] }
}
}
])The operation returns the following results: