news 2026/4/18 13:34:27

【MongoDB实战】5.3 高级聚合场景实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【MongoDB实战】5.3 高级聚合场景实战

文章目录

  • 《MongoDB 实战入门》第5章 进阶查询:聚合管道与数据统计分析
    • 5.3 高级聚合场景实战
      • 前置准备
      • 场景1:按用户等级统计用户数量(g r o u p + group+group+match)
        • 场景需求
        • 数据准备(插入测试数据)
        • 实战聚合代码
        • 代码解析
        • 预期结果
      • 场景2:商品分类统计销量Top3( $group + $sort + $limit)
        • 场景需求
        • 数据准备(插入测试数据)
        • 实战聚合代码
        • 代码解析
        • 预期结果
      • 场景3:日志数据按小时聚合统计($bucket阶段实战)
        • 场景需求
        • 数据准备(插入测试数据)
        • 实战聚合代码
        • 代码解析
        • 预期结果
        • 扩展优化
      • 场景4:关联查询($lookup,模拟关系型数据库JOIN)
        • 场景需求
        • 数据准备(复用users集合,新增订单数据)
        • 实战聚合代码
        • 代码解析
        • 预期结果
      • 实战注意事项

《MongoDB 实战入门》第5章 进阶查询:聚合管道与数据统计分析

5.3 高级聚合场景实战

前置准备

    1. MongoDB版本:推荐5.0+(核心语法兼容低版本)
    1. 客户端:使用mongosh(替代旧版mongoshell)
    1. 核心概念:聚合管道(Aggregation Pipeline)由多个「阶段(Stage)」组成,每个阶段处理数据后传递给下一个阶段,核心阶段包括$match(筛选)、$group(分组)、$sort(排序)、$limit(限制数量)、$bucket(分桶)、$lookup(关联)。

场景1:按用户等级统计用户数量(g r o u p + group+group+match)

场景需求
  • 筛选出「状态为活跃(active)」的用户;

  • 按用户等级(level:1/2/3/4)分组,统计每个等级的用户数量;

  • 按统计数量降序排序,便于查看分布。

数据准备(插入测试数据)
// 切换到测试数据库use mongodb_practice;// 插入用户数据到users集合db.users.insertMany([{name:"张三",level:1,status:"active",registerTime:newDate("2025-01-01")},{name:"李四",level:2,status:"active",registerTime:newDate("2025-01-02")},{name:"王五",level:1,status:"inactive",registerTime:newDate("2025-01-03")},{name:"赵六",level:3,status:"active",registerTime:newDate("2025-01-04")},{name:"钱七",level:2,status:"active",registerTime:newDate("2025-01-05")},{name:"孙八",level:1,status:"active",registerTime:newDate("2025-01-06")},{name:"周九",level:4,status:"inactive",registerTime:newDate("2025-01-07")},{name:"吴十",level:2,status:"active",registerTime:newDate("2025-01-08")}]);

实战聚合代码
// 按等级统计活跃用户数量db.users.aggregate([// 阶段1:筛选活跃用户(减少后续聚合数据量,提升性能){$match:{status:"active"}},// 阶段2:按等级分组,统计数量{
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 8:34:32

Rod快速入门指南:轻松掌握Web自动化测试的完整教程

Rod快速入门指南:轻松掌握Web自动化测试的完整教程 【免费下载链接】rod A Devtools driver for web automation and scraping 项目地址: https://gitcode.com/gh_mirrors/ro/rod 想要快速上手Rod进行Web自动化测试吗?Rod作为一款强大的Devtools驱…

作者头像 李华
网站建设 2026/4/18 8:42:45

2025年UI框架终极对决:Marko与React深度解析与选型指南

2025年UI框架终极对决:Marko与React深度解析与选型指南 【免费下载链接】marko A declarative, HTML-based language that makes building web apps fun 项目地址: https://gitcode.com/gh_mirrors/ma/marko 在当今快速发展的前端技术领域,选择合…

作者头像 李华
网站建设 2026/4/18 8:04:53

终极WebP插件:让Photoshop完美支持现代图像格式

终极WebP插件:让Photoshop完美支持现代图像格式 【免费下载链接】WebPShop Photoshop plug-in for opening and saving WebP images 项目地址: https://gitcode.com/gh_mirrors/we/WebPShop WebPShop是一款专业的Photoshop插件,专门用于打开和保存…

作者头像 李华
网站建设 2026/4/18 6:26:01

OpenMetadata 终极指南:5分钟构建企业级数据治理平台

OpenMetadata 终极指南:5分钟构建企业级数据治理平台 【免费下载链接】OpenMetadata 开放标准的元数据。一个发现、协作并确保数据正确的单一地点。 项目地址: https://gitcode.com/GitHub_Trending/op/OpenMetadata 还在为数据孤岛、质量参差不齐、查找困难…

作者头像 李华
网站建设 2026/4/18 8:09:25

BioSIM抗人LRP6抗体SIM0365:高浓度与灵活选择

在现代生命科学研究中,抗体作为关键工具,广泛应用于基础研究、药物开发及诊断检测等多个领域。其中,针对LRP6(低密度脂蛋白受体相关蛋白6)的抗体因其在Wnt信号通路中的核心作用而备受关注。BioSIM 抗人 LRP6 抗体&…

作者头像 李华
网站建设 2026/4/17 16:12:41

合成植物大战僵尸 安卓原生APP Cocos游戏 支持Sigmob

游戏简介:用户打开游戏观看激励视频广告,其他页面包括开屏广告,插屏广告等内容,用户可根据观看的激励视频广告获得预估收益,预估收益可以进行提现(如果不需要自行关闭或联系客服咨询关闭)后台审…

作者头像 李华