定义
提示
语法
$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 ] }]