$pull
The $pull operator is used to remove from an array all instances of a value or values that match a specified condition. This operator is useful when you need to remove specific elements from an array field within a document.
Parameters
-
field: The name of the array field from which to remove the value(s). -
value: The value or condition that determines which element(s) to remove from the array.
Example (MongoDB Shell)
The following example demonstrates how to use the $pull operator to remove elements from an array field.
Create sample documents
db.restaurants.insertMany([ { name: "Pizza Hut", cuisine: "Italian", features: ["Delivery", "Takeout", "Dine-in"] }, { name: "Sushi Saito", cuisine: "Japanese", features: ["Dine-in", "Private Dining"] }, { name: "Taco Bell", cuisine: "Mexican", features: ["Delivery", "Takeout", "Drive-thru"] } ])
Query example
db.restaurants.updateMany( { cuisine: "Italian" }, { $pull: { features: "Takeout" } } )
Output
{
"acknowledged" : true,
"matchedCount" : 1,
"modifiedCount" : 1
}
The above query removes the "Takeout" feature from all documents where the cuisine field is "Italian".
Code examples
To view a code example for using the $pull command, choose the tab for the language that you want to use: