Docs Menu
Docs Home
/
데이터베이스 매뉴얼
/ / /

$setEquals (집계)

$setEquals

두 개 이상의 배열을 비교하여 동일한 고유 요소가 있으면 true를 반환하고 그렇지 않으면 false를 반환합니다.

$setEquals 의 구문은 다음과 같습니다:

{ $setEquals: [ <expression1>, <expression2>, ... ] }

인수는 각각 배열 로 해석되는 한 유효한 표현식 이 될 수 있습니다. 표현식에 대한 자세한 내용은 표현식을 참조하세요 .

$setEquals은 배열에 집합 연산을 수행하여 배열을 집합으로 취급합니다. 배열에 중복 항목이 포함되어 있으면 $setEquals는 중복 항목을 무시합니다. $setEquals는 요소의 순서를 무시합니다.

세트에 중첩된 배열 요소가 포함된 경우 $setEquals는 중첩된 배열로 내려가지 않고 최상위 수준에서 배열을 평가합니다.

예시
결과
참고 사항
{ $setEquals: [
[ "a", "c" ],
[ "a", "b" ]
] }

false

배열에 동일한 요소가 포함되어 있지 않습니다.

{ $setEquals: [
[ "a", "c" ],
[ "a", "b", "c" ]
] }

false

배열에 동일한 요소가 포함되어 있지 않습니다.

{ $setEquals: [
[ "a", "b", "a" ],
[ "b", "a" ]
] }

true

두 배열 모두 동일한 고유 요소를 포함합니다. 세트로 처리되는 경우 중복은 무시되므로 첫 번째 배열 [ "a", "b" ] 입니다.

{ $setEquals: [
[ "a", "b" ],
[ [ "a", "b" ] ]
] }

false

배열의 요소가 같지 않습니다. 첫 번째 배열 에는 "a""b" 문자열이 포함되어 있고, 두 번째 배열에는 [ "a", "b" ] 배열 포함되어 있습니다.

{ $setEquals: [
[ ],
[ "a", "b" ]
] }

false

배열의 요소가 같지 않습니다. 첫 번째 배열 비어 있고 두 번째 배열 에는 두 개의 문자열 요소가 있습니다.

{ $setEquals: [
[ "a", "a" ],
[ "a", "b" ]
] }

false

배열에 동일한 고유 요소가 포함되어 있지 않습니다. 첫 번째 배열 에는 "a"만 포함되고 두 번째 배열 에는 "a""b"가 포함됩니다.

다음 문서가 포함된 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

이 페이지의 내용