문서 메뉴

문서 홈애플리케이션 개발MongoDB 매뉴얼

minN(배열 연산자)

이 페이지의 내용

  • 정의
  • 구문
  • 행동
  • 예제
$minN

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

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

다음도 참조하세요.

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

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

  • $minNinput 배열에 있는 null 값을 필터링합니다.

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

  • input 배열이 아닌 값으로 확인되면 집계 작업 오류가 발생합니다.

  • input 에 숫자와 문자열 요소가 모두 포함된 경우 숫자 요소는 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 ]}
])

다음 예제에서는 $minN 연산자를 사용하여 각 플레이어의 가장 낮은 점수 두 개를 검색합니다. 가장 낮은 점수는$addFields 에서 만든 새 필드 minScores 에 반환됩니다

db.scores.aggregate([
{ $addFields: { minScores: { $minN: { n: 2, input: "$score" } } } }
])

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

[{
"playerId": 1,
"score": [ 1, 2, 3 ],
"minScores": [ 1, 2 ]
},
{
"playerId": 2,
"score": [ 12, 90, 7, 89, 8 ],
"minScores": [ 7, 8 ]
},
{
"playerId": 3,
"score": [ null ],
"minScores": [ ]
},
{
"playerId": 4,
"score": [ ],
"minScores": [ ]
},
{
"playerId": 5,
"score": [ 1293, "2", 3489, 9 ],
"minScores": [ 9, 1293 ]
}]
← minN(집계 누산기)

이 페이지의 내용