MongoDB聚合运算符:$topN

MongoDB聚合运算符:$topN


$topN聚合运算符返回分组中指定顺序的最前面 n个元素,如果分组中的元素数量小于 n,则返回分组的全部元素。从MongoDB5.2开始支持。

语法

{
   
   
   $topN:
      {
   
   
         n: <expression>,
         sortBy: {
   
    <field1>: <sort order>, <field2>: <sort order> ... },
         output: <expression>
      }
}
  • n用于限制每组结果的数量,必须是正整数表达式,要么是常数,要么取决于$group_id
  • sortBy制定返回结果的顺序,语法类似于$sort
  • output指定分组元素输出的内容,可以是任何合法的表达式。

用法

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

关于null和缺失值的处理

  • $topN不会过滤掉空值
  • $topN会将缺失值转换为null
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:
            {
   
   
               $topN:
                  {
   
   
                     output: [ "$playerId", "$score" ],
                     sortBy: {
   
    "score": 1 },
                     n: 3
                  }
            }
      }
   }
] )

在这个例子中:

  • 使用$documents阶段创建了一些字面量(常量)文档,包含了选手的得分
  • $group阶段根据gameId对文档进行了分组,显然文档中的gameId都是G1
  • PlayerD
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

原子星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值