문서 메뉴
문서 홈
/
MongoDB 매뉴얼
/ / /

$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" ] }
}
}
] )

참고

프로젝트

$project 단계에서는 출력 문서에 포함되는 필드를 지정합니다. 이 예에서 $project 단계는 다음과 같습니다.

  • 출력에서 _id 필드를 제외합니다.

  • 출력에 cakescupcakes 필드를 포함합니다.

  • sameFlavors라는 새 필드에 $setEquals 연산자의 결과를 출력합니다.

이 연산은 다음과 같은 결과를 반환합니다.

{
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
}
← $setDifference (애그리게이션)

이 페이지의 내용