Docs Menu
Docs Home
/
MongoDBマニュアル
/ / /

$minN(配列演算子)

項目一覧

  • 定義
  • 構文
  • 動作
$minN

バージョン 5.2 で追加

配列内の n つの最小値を返します。

Tip

以下も参照してください。

$maxN

$minN の構文は次のとおりです。

{ $minN: { n: <expression>, input: <expression> } }
フィールド
説明
n
正の整数に解決される。 整数は、 $minNが返す配列要素の数を指定します。
input
最小のn要素を返す配列に解決される
  • 1 nの値は指定できません。

  • $minNは、 input配列にあるnull値をフィルタリングします。

  • 指定されたninput配列内の要素数以上の場合、 $minNinput配列内のすべての要素を返します。

  • inputが配列以外の値に解決される場合、集計操作はエラーになります。

  • inputに数値要素と string 要素の両方が含まれている場合、数値要素はBSON 比較順序に従って string 要素の前にソートされます。

次のドキュメントを使用して 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演算子を使用して、各プレイヤーの最低スコアを 2 つ検索します。 最低スコアは、 $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