MongoDB聚合运算符:$top

MongoDB聚合运算符:$top

文章目录

$top聚合运算符返回一个指定顺序分组的第一个元素。

语法

js 复制代码
{
   $top:
      {
         sortBy: { <field1>: <sort order>, <field2>: <sort order> ... },
         output: <expression>
      }
}

字段说明:

字段 是否必须 描述
sortBy 指定结果排序方式,跟$sort一样
output 指定分组元素输出的内容,可以是任何合法的表达式

用法

  • $top不支持作为聚合表达式。
  • $top只支持作为window 操作符
  • 聚合管道调用$top受100M的限制,如果单组超过这一限制将报错。

关于null和缺失值的处理

  • $top不会过滤掉空值,也就是空值也参与排序
  • $top会将缺失值转换为null,也就是缺失值会当做null排序

下面的聚合返回分组中得分最高的文档:

js 复制代码
db.aggregate( [
   {
      $documents: [
         { playerId: "PlayerA", gameId: "G1", score: 1 },
         { playerId: "PlayerB", gameId: "G1", score: 2 },
         { playerId: "PlayerC", gameId: "G1", score: 3 },
         { playerId: "PlayerD", gameId: "G1"},
         { playerId: "PlayerE", gameId: "G1", score: null }
      ]
   },
   {
      $group:
      {
         _id: "$gameId",
         playerId:
            {
               $top:
                  {
                     output: [ "$playerId", "$score" ],
                     sortBy: { "score": -1 }
                  }
            }
      }
   }
] )

在这个例子中:

  • 使用$documents阶段创建了一些字面量(常量)文档,包含了选手的得分
  • $group阶段根据gameId对文档进行了分组,显然文档中的gameId都是G1
  • PlayerD的得分缺失,PlayerE的得分为null,他们的得分都会被当做null处理
  • playerId字段和score字段被指定为输出:["$playerId"," $score"],以数组的形式返回
  • 指定了排序的方式,按照score逆序:sortBy: { "score": -1 }
  • PlayerDPlayerE并列为第一的元素,PlayerD作为第一个score返回
  • 要解决因为多个元素空值导致的问题,就需要添加更多的字段参与到排序
js 复制代码
[
   {
      _id: 'G1',
      playerId: [ [ 'PlayerD', null ] ]
   }
]

举例

使用下面的命令,创建gamescores集合:

js 复制代码
db.gamescores.insertMany([
   { playerId: "PlayerA", gameId: "G1", score: 31 },
   { playerId: "PlayerB", gameId: "G1", score: 33 },
   { playerId: "PlayerC", gameId: "G1", score: 99 },
   { playerId: "PlayerD", gameId: "G1", score: 1 },
   { playerId: "PlayerA", gameId: "G2", score: 10 },
   { playerId: "PlayerB", gameId: "G2", score: 14 },
   { playerId: "PlayerC", gameId: "G2", score: 66 },
   { playerId: "PlayerD", gameId: "G2", score: 80 }
])

查找单个游戏的第一名

使用$top查找单场比赛的第一名:

js 复制代码
db.gamescores.aggregate( [
   {
      $match : { gameId : "G1" }
   },
   {
      $group:
         {
            _id: "$gameId",
            playerId:
               {
                  $top:
                  {
                     output: [ "$playerId", "$score" ],
                     sortBy: { "score": -1 }
                  }
               }
         }
   }
] )

在本例的管道中:

  • 使用$match阶段用一个gameId对结果进行筛选,即:G1
  • 使用$group阶段依据gameId对结果进行分组,本例中只有一个分组G1
  • 使用output : ["$playerId"," $score"]top指定输出字段
  • 使用sortBy: { "score": -1 }按照得分进行逆序排序
  • 使用$top返回游戏得分最高的元素

操作返回下面的结果:

js 复制代码
[ { _id: 'G1', playerId: [ 'PlayerC', 99 ] } ]

查所有游戏的第一名

使用$top查找所有游戏的第一名:

js 复制代码
db.gamescores.aggregate( [
      {
         $group:
         { _id: "$gameId", playerId:
            {
               $top:
                  {
                     output: [ "$playerId", "$score" ],
                     sortBy: { "score": -1 }
                  }
            }
         }
      }
] )

在本例的管道中:

  • 使用$group按照groupId对结果排序
  • 使用$top返回所有游戏中得分最低的
  • 使用output : ["$playerId", "$score"]指定top输出的字段
  • 使用sortBy: { "score": -1 }按照得分进行逆序排序

操作返回下面的结果:

js 复制代码
[
   { _id: 'G2', playerId: [ 'PlayerD', 80 ] },
   { _id: 'G1', playerId: [ 'PlayerC', 99 ] }
]
相关推荐
TDengine (老段)3 分钟前
两分钟掌握 TDengine 全部写入方式
大数据·数据库·时序数据库·tdengine·涛思数据
御风@户外11 分钟前
质数生成函数、质数判断备份
算法·acm
码农君莫笑17 分钟前
《信管通低代码信息管理系统开发平台》Windows环境安装说明
服务器·数据库·windows·低代码·c#·bootstrap·.netcore
闻缺陷则喜何志丹24 分钟前
【C++动态规划】1105. 填充书架|2104
c++·算法·动态规划·力扣·高度·最小·书架
计算机学长felix30 分钟前
基于SpringBoot的“大学生社团活动平台”的设计与实现(源码+数据库+文档+PPT)
数据库·spring boot·后端
Dong雨36 分钟前
六大排序算法:插入排序、希尔排序、选择排序、冒泡排序、堆排序、快速排序
数据结构·算法·排序算法
木与子不厌39 分钟前
微服务自定义过滤器
运维·数据库·微服务
达帮主1 小时前
7.C语言 宏(Macro) 宏定义,宏函数
linux·c语言·算法
派可数据BI可视化1 小时前
连锁餐饮行业数据可视化分析方案
大数据·数据库·数据仓库·数据分析·商业智能bi
dbcat官方1 小时前
1.微服务灰度发布(方案设计)
java·数据库·分布式·微服务·中间件·架构