문서 홈 → 애플리케이션 개발 → MongoDB 매뉴얼
$pop
정의
행동
MongoDB 5.0부터 업데이트 연산자는 문자열 기반 이름이 있는 문서 필드를 사전순으로 처리합니다. 숫자 이름이 있는 필드는 숫자 순서대로 처리됩니다. 자세한 내용은 업데이트 운영자 동작을 참조하십시오.
<field>
이(가) 배열이 아닌 경우 $pop
작업이 실패합니다.
$pop
연산자가 <field>
의 마지막 항목을 제거하면 <field>
는 빈 배열을 보유합니다.
MongoDB 5 부터 시작.0, mongod
는 빈 피연산자 표현식( { }
)과 함께 $pop
과 같은 업데이트 연산자를 사용할 때 더 이상 오류를 발생시키지 않습니다. 빈 업데이트는 변경 사항이 없으며 oplog 항목이 생성되지 않습니다(즉, 작업이 작동하지 않음을 의미합니다).
예제
배열의 첫 번째 항목 제거
students
컬렉션을 생성합니다.
db.students.insertOne( { _id: 1, scores: [ 8, 9, 10 ] } )
다음 예에서는 scores
배열에서 첫 번째 요소인 8을 제거합니다.
db.students.updateOne( { _id: 1 }, { $pop: { scores: -1 } } )
첫 번째 요소인 8이 scores
배열에서 제거되었습니다.
{ _id: 1, scores: [ 9, 10 ] }
배열의 마지막 항목 제거
다음 문서를 students
컬렉션에 추가합니다:
db.students.insertOne( { _id: 10, scores: [ 9, 10 ] } )
다음 예에서는 10 scores
표현식에 를 지정하여 배열에서 마지막 요소인 을 1
$pop
제거합니다.
db.students.updateOne( { _id: 10 }, { $pop: { scores: 1 } } )
마지막 요소인 10이 scores
배열에서 제거되었습니다.
{ _id: 10, scores: [ 9 ] }