Docs Menu
Docs Home
/
MongoDB 매뉴얼
/ / /

maxN(배열 연산자)

이 페이지의 내용

  • 정의
  • 구문
  • 행동
  • 예시
$maxN

버전 5.2에 추가되었습니다.

배열에서 가장 큰 값 n개를 반환합니다.

다음도 참조하세요.

$minN

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

{ $maxN: { n: <expression>, input: <expression> } }
필드
설명
n
양의 정수로 해석되는 표현식입니다. 정수는 $maxN이 반환하는 배열 요소의 수를 지정합니다.
input
최대 n 요소를 반환할 배열 로 해석되는 표현식 입니다.
  • 1보다 작은 n 값은 지정할 수 없습니다.

  • $maxNinput 배열에서 찾은 null 값을 필터링합니다.

  • 지정된 ninput 배열의 요소 수보다 크거나 같으면 $maxNinput 배열의 모든 요소를 반환합니다.

  • 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 ]
}]

돌아가기

$maxN

이 페이지의 내용