Bird
Raised Fist0
MongoDBquery~30 mins

$push operator for adding to arrays in MongoDB - Mini Project: Build & Apply

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
$push Operator to Add Items to Arrays in MongoDB
📖 Scenario: You are managing a simple online bookstore database. Each book document has a title and an array of reviews. You want to add new reviews to the books as customers submit them.
🎯 Goal: Build a MongoDB update operation using the $push operator to add new review entries to the reviews array of a book document.
📋 What You'll Learn
Create a collection named books with one book document containing a title and an empty reviews array.
Define a new review object with user and comment fields.
Use the $push operator to add the new review to the reviews array of the book.
Complete the update command to modify the correct book document by its title.
💡 Why This Matters
🌍 Real World
Adding user-generated content like reviews or comments to documents is common in many applications such as e-commerce, blogs, and social media.
💼 Career
Understanding how to update array fields in MongoDB documents is essential for backend developers working with NoSQL databases.
Progress0 / 4 steps
1
Create the books collection with one book document
Create a collection called books and insert one document with title set to 'Learn MongoDB' and an empty array reviews.
MongoDB
Hint

Use insertOne to add a document with the specified fields.

2
Define a new review object
Create a variable called newReview that holds an object with user set to 'Alice' and comment set to 'Great book!'.
MongoDB
Hint

Use const newReview = { user: 'Alice', comment: 'Great book!' } to define the review.

3
Use $push to add the review to the book's reviews array
Write an update command using db.books.updateOne to find the book with title equal to 'Learn MongoDB' and use $push to add newReview to the reviews array.
MongoDB
Hint

Use updateOne with a filter and {$push: { reviews: newReview }} to add the review.

4
Complete the update command with options
Add the option { upsert: false } as the third argument to updateOne to ensure no new document is created if the book is not found.
MongoDB
Hint

Pass { upsert: false } as the third argument to updateOne.

Practice

(1/5)
1. What does the $push operator do in MongoDB?
easy
A. Adds a new element to the end of an array field in a document
B. Removes an element from an array field in a document
C. Replaces the entire array field with a new array
D. Creates a new collection in the database

Solution

  1. Step 1: Understand the purpose of $push

    The $push operator is used to add elements to an existing array field inside a MongoDB document.
  2. Step 2: Compare with other options

    Options A, C, and D describe different operations: removing elements, replacing arrays, or creating collections, which are not what $push does.
  3. Final Answer:

    Adds a new element to the end of an array field in a document -> Option A
  4. Quick Check:

    $push adds elements [OK]
Hint: Remember: $push always adds to array end [OK]
Common Mistakes:
  • Confusing $push with $pull (which removes items)
  • Thinking $push replaces the whole array
  • Mixing $push with collection creation commands
2. Which of the following is the correct syntax to add the value 5 to the array field numbers in a document where _id is 1?
easy
A. db.collection.updateOne({_id: 1}, {$push: {numbers: 5}})
B. db.collection.updateOne({_id: 1}, {$push: numbers: 5})
C. db.collection.updateOne({_id: 1}, {$push: {numbers => 5}})
D. db.collection.updateOne({_id: 1}, {$push: {numbers: [5]}})

Solution

  1. Step 1: Identify correct $push syntax

    The correct syntax uses an object with the field name as key and the value to add as value: {$push: {field: value}}.
  2. Step 2: Analyze each option

    db.collection.updateOne({_id: 1}, {$push: {numbers: 5}}) matches the correct syntax. db.collection.updateOne({_id: 1}, {$push: numbers: 5}) misses curly braces around the field-value pair. db.collection.updateOne({_id: 1}, {$push: {numbers => 5}}) uses an invalid arrow syntax. db.collection.updateOne({_id: 1}, {$push: {numbers: [5]}}) pushes the array [5] as a single element instead of adding the scalar value 5.
  3. Final Answer:

    db.collection.updateOne({_id: 1}, {$push: {numbers: 5}}) -> Option A
  4. Quick Check:

    Correct $push syntax uses {$push: {field: value}} [OK]
Hint: Use {$push: {field: value}} with braces [OK]
Common Mistakes:
  • Omitting braces around field-value pair
  • Using wrong symbols like => instead of :
  • Pushing an array when a single value is intended
3. Given the document { _id: 1, tags: ["red", "blue"] }, what will be the tags array after running db.collection.updateOne({_id: 1}, {$push: {tags: "green"}})?
medium
A. ["red", "blue"]
B. ["red", "green", "blue"]
C. ["green", "red", "blue"]
D. ["red", "blue", "green"]

Solution

  1. Step 1: Understand $push effect on array

    The $push operator adds the new element to the end of the existing array.
  2. Step 2: Apply $push to the given array

    Starting with ["red", "blue"], pushing "green" adds it at the end, resulting in ["red", "blue", "green"].
  3. Final Answer:

    ["red", "blue", "green"] -> Option D
  4. Quick Check:

    New item added at array end [OK]
Hint: Remember $push adds at the end of array [OK]
Common Mistakes:
  • Assuming $push adds at the start
  • Replacing the whole array instead of adding
  • Confusing order of elements after push
4. You want to add multiple values ["yellow", "purple"] to the colors array in a document with _id: 2. Which update command will NOT work correctly?
medium
A. db.collection.updateOne({_id: 2}, {$push: {colors: { $each: ["yellow", "purple"] }}})
B. db.collection.updateOne({_id: 2}, {$push: {colors: ["yellow", "purple"]}})
C. db.collection.updateOne({_id: 2}, {$push: {colors: {$each: ["yellow", "purple"]}}})
D. db.collection.updateOne({_id: 2}, {$push: {colors: { $each: ["yellow", "purple" ] }}})

Solution

  1. Step 1: Understand how to push multiple items

    To add multiple items to an array, $push must be combined with $each inside the update document.
  2. Step 2: Analyze each option

    Options B, C, and D correctly use $each to add multiple values. db.collection.updateOne({_id: 2}, {$push: {colors: ["yellow", "purple"]}}) tries to push an array directly, which will add the entire array as a single element, not multiple elements.
  3. Final Answer:

    db.collection.updateOne({_id: 2}, {$push: {colors: ["yellow", "purple"]}}) -> Option B
  4. Quick Check:

    Use $each to push multiple items [OK]
Hint: Use $each inside $push for multiple items [OK]
Common Mistakes:
  • Pushing an array directly instead of using $each
  • Forgetting curly braces around $each
  • Using wrong operators like $addToSet instead of $push
5. You have a document { _id: 3, tasks: ["task1"] }. You want to add "task2" and "task3" only if they are not already in the array. Which update command correctly achieves this?
hard
A. db.collection.updateOne({_id: 3}, {$push: {tasks: { $each: ["task2", "task3"] }}})
B. db.collection.updateOne({_id: 3}, {$push: {tasks: { $addToSet: ["task2", "task3"] }}})
C. db.collection.updateOne({_id: 3}, {$addToSet: {tasks: { $each: ["task2", "task3"] }}})
D. db.collection.updateOne({_id: 3}, {$push: {tasks: ["task2", "task3"]}})

Solution

  1. Step 1: Understand difference between $push and $addToSet

    $push adds items regardless of duplicates. $addToSet adds items only if they don't exist already.
  2. Step 2: Analyze the commands

    db.collection.updateOne({_id: 3}, {$addToSet: {tasks: { $each: ["task2", "task3"] }}}) uses $addToSet with $each to add multiple unique items. Options A and D use $push which can add duplicates. db.collection.updateOne({_id: 3}, {$push: {tasks: { $addToSet: ["task2", "task3"] }}}) incorrectly nests $addToSet inside $push, which is invalid syntax.
  3. Final Answer:

    db.collection.updateOne({_id: 3}, {$addToSet: {tasks: { $each: ["task2", "task3"] }}}) -> Option C
  4. Quick Check:

    Use $addToSet with $each for unique additions [OK]
Hint: Use $addToSet with $each to avoid duplicates [OK]
Common Mistakes:
  • Using $push when duplicates should be avoided
  • Nesting $addToSet inside $push incorrectly
  • Forgetting $each when adding multiple items