기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.
$pull
$pull 연산자는 배열에서 지정된 조건과 일치하는 값 또는 값의 모든 인스턴스를 제거하는 데 사용됩니다. 이 연산자는 문서 내의 배열 필드에서 특정 요소를 제거해야 할 때 유용합니다.
파라미터
예제(MongoDB 쉘)
다음 예제에서는 $pull 연산자를 사용하여 배열 필드에서 요소를 제거하는 방법을 보여줍니다.
샘플 문서 생성
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"]
}
])
쿼리 예제
db.restaurants.updateMany(
{ cuisine: "Italian" },
{ $pull: { features: "Takeout" } }
)
출력
{
"acknowledged" : true,
"matchedCount" : 1,
"modifiedCount" : 1
}
위의 쿼리는 cuisine 필드가 "이탈리아어"인 모든 문서에서 "Takeout" 기능을 제거합니다.
코드 예제
$pull 명령을 사용하기 위한 코드 예제를 보려면 사용하려는 언어의 탭을 선택합니다.
- Node.js
-
const { MongoClient } = require('mongodb');
async function updateRestaurants() {
const client = await MongoClient.connect('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false');
const db = client.db('test');
const restaurants = db.collection('restaurants');
await restaurants.updateMany(
{ cuisine: 'Italian' },
{ $pull: { features: 'Takeout' } }
);
const updatedRestaurants = await restaurants.find({}).toArray();
console.log(updatedRestaurants);
await client.close();
}
updateRestaurants();
- Python
-
from pymongo import MongoClient
def update_restaurants():
client = MongoClient('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false')
db = client.test
restaurants = db.restaurants
result = restaurants.update_many(
{ 'cuisine': 'Italian' },
{ '$pull': { 'features': 'Takeout' } }
)
updated_restaurants = list(restaurants.find({}))
print(updated_restaurants)
client.close()
update_restaurants()