前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mongoose: aggregate() 方法实现聚合函数

Mongoose: aggregate() 方法实现聚合函数

作者头像
szhshp
发布2022-09-21 10:29:12
3.8K0
发布2022-09-21 10:29:12
举报
文章被收录于专栏:szhshp 的第四边境中转站

需求描述

首先我有一个 Item 的 collection:

代码语言:javascript
复制
type Item {
  _id: String
  itemname: String!
    itemid: String!
    itemtype: String!
    parent_id: String
}

///////////////////
/// 主要是下面这一些部分

type Query {
  getItemSummary: ItemSummaryResponse
}
type ItemSummaryResponse {
  data: [ItemSummary]
  success: Boolean
}
type ItemSummary {
  _id: String
  count: Int
}

gql 端调用的方法:

代码语言:javascript
复制
{
  getItemSummary {
    data{
      _id
      count
    }
    success
  }
}

然按照其中的类别 (itemtype) 进行总计:

那么实际上在后台 mongoose 里面需要这么写:

代码语言:javascript
复制
getItemSummary: root => Item.aggregate([{
  $group: {
    _id: '$itemtype',
    count: {
      $sum: 1,
    },
  },
}, ]).then((res) => {
  if (res === null) {
    return {
      success: 0,
      errors: ['sadfsdfsdf']
    };
  }

  return ({
    success: 1,
    errors: [],
    data: res,
  });
}),

聚合函数 aggregate() 的使用

首先写明按照哪个 field 进行聚合

代码语言:javascript
复制
$group: {
    _id: '$itemtype', 
        // 这个地方比较重要,首先左边一定要写成 _id, 最后在前端通过 gql 取的时候也是写 _id
        // 另外重要是这个 key 的值是 $itemtype, 说明根据 itemtype 进行 group, 直接写 $ + fieldname 即可
    count: {
      $sum: 1,
    },
  },

因为 $group 里面对应需要聚合操作的列必须写成 _id , 否则会出现 The field 'xxx' must be an accumulator object 的报错信息

另外 SQL 的聚合函数都可以用到这里:

聚合管道

管道在 Unix 和 Linux 中一般用于将当前命令的输出结果作为下一个命令的参数。

基本上就是逐个执行聚合方法里面的方法.

上方的聚合函数仅仅执行了对一个 field 的聚合:

代码语言:javascript
复制
Item.aggregate([{
  $group: {
    _id: '$itemtype',
    count: {
      $sum: 1
    }
  }
}, ])

但是实际上可以在这些操作之前之后加更多的操作.

比如想要将,70 分到 90 分之间的数据先筛选出来再进行 group:

代码语言:javascript
复制
db.articles.aggregate([{
    $match: {
      score: {
        $gt: 70,
        $lte: 90
      }
    }
  },
  {
    $group: {
      _id: null,
      count: {
        $sum: 1
      }
    }
  }
]);

常用的几个操作

  • $project:修改输入文档的结构。可以用来重命名、增加或删除域,也可以用于创建计算结果以及嵌套文档。
  • $match:用于过滤数据,只输出符合条件的文档。使用 MongoDB 的标准查询操作。
  • $limit:用来限制 MongoDB 聚合管道返回的文档数。
  • $skip:在聚合管道中跳过指定数量的文档,并返回余下的文档。
  • $unwind:将文档中的某一个数组类型字段拆分成多条,每条包含数组中的一个值。
  • $group:将集合中的文档分组,可用于统计结果。
  • $sort:将输入文档排序后输出。
  • $geoNear:输出接近某一地理位置的有序文档。
实例

$project 实例

0 为不显示,1 为显示,默认情况下 _id 字段是 1

代码语言:javascript
复制
db.articles.aggregate({
    $project: {
        _id: 0,
        title: 1,
        by_user: 1,
    }
});

 // 返回
{ "title" : "MongoDB Overview", "by_user" : "runoob.com" }
{ "title" : "NoSQL Overview", "by_user" : "runoob.com" }
{ "title" : "Neo4j Overview", "by_user" : "Neo4j" }

$match 实例

match 用于获取分数大于 70 小于或等于 90 记录,然后将符合条件的记录送到下一阶段group 管道操作符进行处理。

代码语言:javascript
复制
db.articles.aggregate([{
    $match: {
      score: {
        $gt: 70,
        $lte: 90
      }
    }
  },
  {
    $group: {
      _id: null,
      count: {
        $sum: 1
      }
    }
  }
]);

 // 返回
{ "_id" : null, "count" : 1 }

$skip 实例

经过 $skip 管道操作符处理后,前 2 个文档被"过滤"掉。

代码语言:javascript
复制
db.col_1.aggregate({ $skip: 2 });

参考文献

https://www.jianshu.com/p/baea1bce6de3

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-09-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 需求描述
  • 聚合函数 aggregate() 的使用
  • 聚合管道
    • 常用的几个操作
      • 实例
  • 参考文献
相关产品与服务
云数据库 MongoDB
腾讯云数据库 MongoDB(TencentDB for MongoDB)是腾讯云基于全球广受欢迎的 MongoDB 打造的高性能 NoSQL 数据库,100%完全兼容 MongoDB 协议,支持跨文档事务,提供稳定丰富的监控管理,弹性可扩展、自动容灾,适用于文档型数据库场景,您无需自建灾备体系及控制管理系统。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档