使用MongoDB聚合查询可在Node.js中通过原生驱动或Mongoose实现,用于数据统计、分组、排序等复杂分析。基本结构为aggregate()方法接收管道数组,常用阶段包括$match筛选、$group分组计算、$sort排序、$project字段重塑及$limit/$skip分页。示例中统计已完成订单的用户总金额并取前五名。Node.js原生驱动需安装mongodb包,连接后调用aggregate()并传入管道操作,如筛选shipped状态订单、按产品ID分组计数并降序排列。Mongoose则语法更贴近Schema,支持链式调用,可用$lookup实现跨集合左连接,如关联用户信息后按城市分组求平均评分。合理组合管道阶段可提升数据处理能力,建议在$match和$sort前创建索引以优化性能,避免全表扫描。

服务端JavaScript中使用MongoDB进行聚合查询,通常是在Node.js环境下通过官方MongoDB驱动或Mongoose库来实现。聚合操作用于处理数据并返回计算结果,比如统计、分组、排序、筛选等,适合复杂的数据分析场景。
聚合查询基本结构
MongoDB的聚合通过aggregate()方法执行,接收一个管道操作数组,每个阶段对数据流进行处理。
常见聚合阶段包括:
- $match:筛选符合条件的文档
- $group:按字段分组,常配合$sum、$avg等累计操作符使用
- $sort:对结果排序
- $project:重塑输出字段结构
- $limit 和 $skip:控制返回数量,用于分页
示例:统计每个用户订单总金额,并按金额降序排列前5名
立即学习“Java免费学习笔记(深入)”;
db.orders.aggregate([{ $match: { status: "completed" } },
{ $group: { _id: "$userId", total: { $sum: "$amount" } } },
{ $sort: { total: -1 } },
{ $limit: 5 }
])
在Node.js中使用原生驱动
安装MongoDB驱动:npm install mongodb
mallcloud商城基于SpringBoot2.x、SpringCloud和SpringCloudAlibaba并采用前后端分离vue的企业级微服务敏捷开发系统架构。并引入组件化的思想实现高内聚低耦合,项目代码简洁注释丰富上手容易,适合学习和企业中使用。真正实现了基于RBAC、jwt和oauth2的无状态统一权限认证的解决方案,面向互联网设计同时适合B端和C端用户,支持CI/CD多环境部署,并提
代码示例:
const { MongoClient } = require('mongodb');async function aggregateOrders() {
const client = new MongoClient('mongodb://localhost:27017');
await client.connect();
const db = client.db('shop');
const result = await db.collection('orders')
.aggregate([
{ $match: { status: "shipped" } },
{ $group: { _id: "$productId", count: { $sum: 1 } } },
{ $sort: { count: -1 } }
]).toArray();
console.log(result);
await client.close();
}
使用Mongoose进行聚合
Mongoose也支持.aggregate()方法,语法更贴近Schema定义。
示例:
Order.aggregate([{
$lookup: {
from: 'users',
localField: 'userId',
foreignField: '_id',
as: 'user'
}
},
{ $unwind: "$user" },
{ $group: { _id: "$user.city", avgScore: { $avg: "$score" } } }
])
.then(result => console.log(result))
.catch(err => console.error(err));
其中$lookup用于实现类似SQL的左连接,是跨集合分析的重要工具。
基本上就这些。掌握聚合管道的组合方式,能大幅提升服务端数据处理能力。注意性能优化,如在$match和$sort前添加索引,避免全表扫描。不复杂但容易忽略。









