node.js mongoose aggregate

目录

官方文档

简述

Aggregate的原型方法

aggregate进行操作


官方文档

Mongoose v8.0.3: Aggregate

简述

在 Mongoose 中,Aggregate 是用于执行 MongoDB 聚合操作的类。MongoDB 聚合操作是一种强大的数据处理工具,可以用于对集合中的文档进行变换和计算

通过Model.aggregate创建一个aggregate(Aggregate类的实例)

javascript 复制代码
const aggregate = Model.aggregate()

Aggregate的原型方法

aggregate进行操作

对aggregate对象进行操作

javascript 复制代码
aggregate.match({...})
aggregate.group({...})
aggregate.sort({...})
aggregate.project('...')

aggregate链式操作,因为Aggregate的原型方法返回的是this(aggregate实例自身)

javascript 复制代码
aggregate.match({...}).group({...}).sort({...}).project('...')

或者通过传入pipeline参数

javascript 复制代码
const aggregate = await Model.aggregate([
  {
    $match: { ... }
  },
  {
    $group: { ... }
  },
  {
    $sort: { ... }
  },
  {
    $match: { ... }
  }
]);

控制台打印aggregate查看所积累的pipeline操作

得到查询结果

也可通过async await的方式获得查询结果

javascript 复制代码
//async try... catch

const resQuery = await aggregate

完整的操作,只是示例

javascript 复制代码
  const aggregate = Tour.aggregate([
    {
      $match: { ratingsAverage: { $gte: 4.5 } }
    },
    {
      $group: {
        _id: { $toUpper: '$difficulty' },
        numTours: { $sum: 1 },
        numRatings: { $sum: '$ratingsQuantity' },
        avgRating: { $avg: '$ratingsAverage' },
        avgPrice: { $avg: '$price' },
        minPrice: { $min: '$price' },
        maxPrice: { $max: '$price' }
      }
    },
    {
      $sort: { avgPrice: 1 }
    },
    {
      $match: { _id: { $ne: 'EASY' } }
    }
  ]);
  const stats = await aggregate
相关推荐
湖边看客30 分钟前
在 Windows PowerShell 里给 Node.js 设置内存上限
node.js
zhensherlock1 小时前
Protocol Launcher 系列:Beorg 高效任务管理的协议支持
前端·javascript·typescript·node.js·自动化·github·js
杨云龙UP1 小时前
Docker 部署 MongoDB 6.0 数据库每日自动备份实践:本地 + 异地保留 7 天_20260429
linux·运维·数据库·mongodb·docker·容器·centos
shao91851616 小时前
第3章(2)——使用Gradio JavaScript Client
javascript·node.js·cdn·gradio·job·events·playcode
稳联技术老娜16 小时前
Profinet转EtherCAT网关通讯架构及EtherCAT超距故障解决原理
mongodb
Rabbit_QL20 小时前
npm 不是“前端的包管理器“—它是 Node.js 的
前端·npm·node.js
是大强21 小时前
nvm安装node成功npm失败
前端·npm·node.js
donecoding1 天前
Claude Code (cc) 升级 2.1.121 报错“Native Binary”全记录
node.js·claude
风景的人生1 天前
nvm下载node找不到nodejs文件夹,但下载不报错(NVM安装Node.js失败)
node.js
别来无恙blwy2 天前
windows MongoDB升级-自动升级脚本-自动检测升级到任意版本
数据库·windows·mongodb