maxN(배열 연산자)
정의
구문
$maxN
의 구문은 다음과 같습니다:
{ $maxN: { n: <expression>, input: <expression> } }
필드 | 설명 |
---|---|
| 양의 정수로 해석되는 표현식 입니다. 정수는 가 반환하는 배열 요소의 수를 |
| 최대 |
행동
1
보다 작은n
값은 지정할 수 없습니다.$maxN
은input
배열에서 찾은null
값을 필터링합니다.지정된
n
이input
배열의 요소 수보다 크거나 같으면$maxN
은input
배열의 모든 요소를 반환합니다.input
배열이 아닌 값으로 확인되면 집계 작업 오류가 발생합니다.input
에 숫자 및 string 요소가 모두 포함된 경우 string 요소는 BSON 비교 순서에 따라 숫자 요소보다 먼저 정렬됩니다.
예시
다음 문서로 scores
컬렉션을 생성합니다.
db.scores.insertMany([ { "playerId" : 1, "score" : [ 1, 2, 3 ] }, { "playerId" : 2, "score" : [ 12, 90, 7, 89, 8 ] }, { "playerId" : 3, "score" : [ null ] }, { "playerId" : 4, "score" : [ ] } { "playerId" : 5, "score" : [ 1293, "2", 3489, 9 ]} ])
다음 예시 에서는 $maxN
연산자 를 사용하여 각 플레이어의 가장 높은 점수 두 개를 조회 합니다. $addFields
에서 만든 새 필드 maxScores
에 가장 높은 점수가 반환됩니다
db.scores.aggregate([ { $addFields: { maxScores: { $maxN: { n: 2, input: "$score" } } } } ])
이 연산은 다음과 같은 결과를 반환합니다.
[{ "playerId": 1, "score": [ 1, 2, 3 ], "maxScores": [ 3, 2 ] }, { "playerId": 2, "score": [ 12, 90, 7, 89, 8 ], "maxScores": [ 90, 89 ] }, { "playerId": 3, "score": [ null ], "maxScores": [ ] }, { "playerId": 4, "score": [ ], "maxScores": [ ] }, { "playerId": 5, "score": [ 1293, "2", 3489, 9 ], "maxScores": [ "2", 3489 ] }]