$addToSet
정의
호환성
다음 환경에서 호스팅되는 배포에 $addToSet
사용할 수 있습니다.
MongoDB Atlas: 클라우드에서의 MongoDB 배포를 위한 완전 관리형 서비스
MongoDB Enterprise: MongoDB의 구독 기반 자체 관리 버전
MongoDB Community: MongoDB의 소스 사용 가능 무료 자체 관리 버전
구문
$addToSet
연산자의 형식은 다음과 같습니다.
{ $addToSet: { <field1>: <value1>, ... } }
내장된 문서나 배열에 <field>
기호를 지정하려면 점 표기법을사용하십시오.
행동
MongoDB 5.0부터 업데이트 연산자는 문자열 기반 이름이 있는 문서 필드를 사전순으로 처리합니다. 숫자 이름이 있는 필드는 숫자 순서대로 처리됩니다. 자세한 내용은 업데이트 운영자 동작을 참조하십시오.
$addToSet
은 집합에 추가된 중복 항목이 없도록 보장하지만, 이미 존재하는 중복 요소에는 영향을 주지 않습니다. $addToSet
은 수정된 집합 내 요소들의 특정 순서를 보장하지 않습니다.
MongoDB 5.0부터 빈 피연산자 표현식( { }
)과 함께 $addToSet
과 같은 업데이트 연산자를 사용할 때 mongod
에서 더 이상 오류가 발생하지 않습니다. 업데이트가 비어 있으면 변경 사항이 없으며 oplog 항목이 생성되지 않습니다(즉, 작업이 작동하지 않음을 의미합니다).
누락된 필드
업데이트할 문서에 없는 필드에 $addToSet
를 사용하면 $addToSet
는 지정된 값을 요소로 사용하여 배열 필드를 생성합니다.
필드는 배열이 아닙니다.
$addToSet
을 배열이 아닌 필드에 사용하면 작업이 실패합니다.
예를 들어 pigments
컬렉션을 만듭니다.
db.pigments.insertOne( { _id: 1, colors: "blue, green, red" } )
colors
필드가 배열이 아닙니다. 다음 $addToSet
작업이 실패했습니다.
db.pigments.updateOne( { _id: 1 }, { $addToSet: { colors: "mauve" } } )
추가할 값은 배열입니다.
값이 배열인 경우 $addToSet
는 전체 배열을 단일 요소로 추가합니다.
alphabet
컬렉션을 생성합니다.
db.alphabet.insertOne( { _id: 1, letters: ["a", "b"] } )
다음 작업은 letters
필드에 배열 [ "c", "d" ]
을 추가합니다.
db.alphabet.updateOne( { _id: 1 }, { $addToSet: { letters: [ "c", "d" ] } } )
배열 [ "c", "d" ]
이 단일 요소로 추가됩니다.
{ _id: 1, letters: [ 'a', 'b', [ 'c', 'd' ] ] }
문서로 값을 추가하기
값이 문서일 경우, 배열 내 존재하는 문서가 추가하려는 문서와 완전히 일치할 때 MongoDB는 그 문서를 중복으로 간주합니다. 즉, 기존 문서가 동일한 필드와 값을 가지고 있고 필드의 순서까지 일치해야 합니다. 따라서 필드의 순서가 중요하며, MongoDB에게 문서가 기존 배열 요소의 중복인지 판단하기 위해 문서 내 일부 필드만 비교하도록 지정하는 것은 불가능합니다.
예시
inventory
컬렉션을 생성합니다.
db.inventory.insertOne( { _id: 1, item: "polarizing_filter", tags: [ "electronics", "camera" ] } )
배열에 추가
다음 작업은 "accessories"
배열에 존재하지 않으므로 "accessories"
요소를 tags
배열에 추가합니다.
db.inventory.updateOne( { _id: 1 }, { $addToSet: { tags: "accessories" } } )
이미 존재하는 값
다음 $addToSet
연산은 "camera"
가 이미 tags
배열의 요소이므로 효과가 없습니다.
db.inventory.updateOne( { _id: 1 }, { $addToSet: { tags: "camera" } } )
$each
Modifier
$addToSet
연산자를 $each
수정자와 함께 사용할 수 있습니다. $each
수정자를 사용하면 $addToSet
연산자가 배열 필드에 여러 값을 추가할 수 있습니다.
컬렉션 inventory
에는 다음 문서가 있습니다.
{ _id: 2, item: "cable", tags: [ "electronics", "supplies" ] }
그 후 다음 작업에서는 $each
수정자와 함께 $addToSet
연산자를 사용하여 tags
배열에 여러 요소를 추가합니다.
db.inventory.updateOne( { _id: 2 }, { $addToSet: { tags: { $each: [ "camera", "electronics", "accessories" ] } } } )
이 작업은 tags
배열에 "camera"
및 "accessories"
만 추가합니다. "electronics"
이 이미 배열에 있었습니다:
{ _id: 2, item: "cable", tags: [ "electronics", "supplies", "camera", "accessories" ] }