当前位置: 首页 > news >正文

【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:按等级分组,统计数量{
http://www.jsqmd.com/news/105736/

相关文章:

  • 16、编程中的条件判断与循环结构详解
  • 如何快速提取RPA文件?unrpa工具完整使用指南与技巧
  • Kubernetes 的部署方式 (一)通过 Minikube 部署
  • 全文搜索模块 - Cordova与OpenHarmony混合开发实战
  • 【MongoDB实战】6.1 索引基础:为什么需要索引
  • 零基础入门EmotiVoice:新手快速上手教程
  • BioSIM 抗人 TGFB1/TGF-beta-1抗体SIM0369:多步纯化工艺,高纯度高稳定性
  • 终极version-manager完整配置指南:5步轻松管理70+开发工具
  • 获取京东商品评论数据,jd.item_reviewAPI接口指南
  • FindSomething信息提取插件终极指南:浏览器隐私安全完整教程
  • Rod快速入门指南:轻松掌握Web自动化测试的完整教程
  • 基于Web的新能源汽车销售网站的设计与实现开题报告
  • 21、网络服务器相关知识详解
  • RuoYi-Cloud-Plus SSE实时推送:企业级消息通信终极指南
  • 字幕搜索终极解决方案:SubFinder 3分钟快速上手指南
  • “微信拒绝,阿里封锁:新兴手机品牌如何面对平台巨头的联合打压?”
  • EmotiVoice vs 其他TTS:情感表达能力全面对比
  • EmotiVoice语音合成延迟优化技巧:适合实时交互场景的配置建议
  • Question:压缩字符串(java)
  • 【spring源码】从废弃的XmlBeanFactory到XmlBeanDefinitionReader
  • GroundingDINO终极指南:零代码实现语言驱动目标检测
  • 高效Bandcamp下载完整指南:快速获取高品质音乐的便捷方法
  • Cocos Creator三消游戏开发终极指南:快速构建完整消除系统
  • 基于OpenCV的人脸五官识别系统研究
  • 5分钟修复Dokploy中.traefik.me证书错误,恢复安全访问
  • 智能代理驱动开发:BMAD框架的工程化实践与架构解析
  • Next.js博客模板:5分钟快速搭建专业级技术博客的完整指南
  • drawio-libs图标库终极指南:打造专业级技术图表
  • 解密染色质密码:TOBIAS如何让ATAC-seq数据“说话“
  • Android模糊视觉效果的完整实现方案