$pull - Amazon DocumentDB

기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.

$pull

$pull 연산자는 배열에서 지정된 조건과 일치하는 값 또는 값의 모든 인스턴스를 제거하는 데 사용됩니다. 이 연산자는 문서 내의 배열 필드에서 특정 요소를 제거해야 할 때 유용합니다.

파라미터

  • field: 값을 제거할 배열 필드의 이름입니다().

  • value: 배열에서 제거할 요소(들)를 결정하는 값 또는 조건입니다.

예제(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()