$setEquals (집계)
정의
$setEquals
두 개 이상의 배열을 비교하여 동일한 고유 요소가 있으면
true
를 반환하고 그렇지 않으면false
를 반환합니다.$setEquals
의 구문은 다음과 같습니다:{ $setEquals: [ <expression1>, <expression2>, ... ] } 인수는 각각 배열 로 해석되는 한 유효한 표현식 이 될 수 있습니다. 표현식에 대한 자세한 내용은 표현식 연산자를 참조하세요.
행동
$setEquals
은 배열에 집합 연산을 수행하여 배열을 집합으로 취급합니다. 배열에 중복 항목이 포함되어 있으면 $setEquals
는 중복 항목을 무시합니다. $setEquals
는 요소의 순서를 무시합니다.
세트에 중첩된 배열 요소가 포함된 경우 $setEquals
는 중첩된 배열로 내려가지 않고 최상위 수준에서 배열을 평가합니다.
예시 | 결과 |
---|---|
{ $setEquals: [ [ "a", "b", "a" ], [ "b", "a" ] ] } | true |
{ $setEquals: [ [ "a", "b" ], [ [ "a", "b" ] ] ] } | false |
예시
다음 문서가 포함된 bakeryOrders
collection을 생각해 보세요.
db.bakeryOrders.insertMany( [ { _id: 0, cakes: ["chocolate", "vanilla"], cupcakes: ["chocolate", "vanilla"] }, { _id: 1, cakes: ["chocolate", "vanilla"], cupcakes: ["vanilla", "chocolate"] }, { _id: 2, cakes: ["chocolate", "chocolate"], cupcakes: ["chocolate"] }, { _id: 3, cakes: ["vanilla"], cupcakes: ["chocolate"] }, { _id: 4, cakes: ["vanilla"], cupcakes: [] } ] )
다음 작업은 $setEquals
연산자 를 사용하여 각 순서의 cakes
배열 과 cupcakes
배열 에 동일한 맛이 포함되어 있는지 확인합니다.
db.bakeryOrders.aggregate( [ { $project: { _id: 0, cakes: 1, cupcakes: 1, sameFlavors: { $setEquals: [ "$cakes", "$cupcakes" ] } } } ] )
참고
프로젝트
이 연산은 다음과 같은 결과를 반환합니다.
{ cakes: [ "chocolate", "vanilla" ], cupcakes: [ "chocolate", "vanilla" ], sameFlavors: true }, { cakes: [ "chocolate", "vanilla" ], cupcakes: [ "vanilla", "chocolate" ], sameFlavors: true }, { cakes: [ "chocolate", "chocolate" ], cupcakes: [ "chocolate" ], sameFlavors: true }, { cakes: [ "vanilla" ], cupcakes: [ "chocolate" ], sameFlavors: false }, { cakes: [ "vanilla" ], cupcakes: [], sameFlavors: false }