mongodb嵌套聚合

db.order.aggregate([
    {
        $match: {
				// 下单时间
				 "createTime": {
                $gte: ISODate("2024-05-01T00:00:00Z"),
                $lte: ISODate("2024-05-31T23:59:59Z")
            }
						// 商品名称
						,
            "goods.productName": /美国皓齿/
						,//订单状态  2:待发货 3:已发货 4:交易成功
						 "status": { $in: [2, 3, 4] }
        }
    }
		,
    {
			// 将订单集合中的商品数组拆开单个商品
        $unwind: "$goods"
    },
//    // Match goods with productName containing "美国皓齿"
    {
			// 再次过滤商品名称中包含美国皓齿的商品
        $match: {
            "goods.productName": /美国皓齿/
        }
    },
    {
        $group: {
            _id: 
							{
								// 根据订单编号进行分组统计
								orderNo:"$orderNo"
								//,uniformCode:"$goods.uniformCode" 多分组直接再加个字段即可,这个例子不需要
							},
							// 根据订单编号分组算出美国皓齿的商品数量乘单价满499的订单
            totalGoodsPrice: {
                $sum: {
                    $multiply: ["$goods.amount", "$goods.unitPrice"]
                }
            },
						// 获取商品数组
						goods:{$push:"$goods"},
						// 获取发货地址
						area:{ $push: "$address.area" }
//						orderStatus:{$push:"$status"}		
        }
    },
    {
				// 过滤单价满499的订单
        $match: {
            totalGoodsPrice: { $gte: 499 }
        }
    },
				// 将按照订单分组后的数组再次按照商品拆开
		    {
        $unwind: "$goods"
    },
			// 按照订单号排序
		  { $sort : { orderNo : 1}},
		{
			        $project: {
            _id: 0,
            订单号: "$_id.orderNo",
						uniformCode: "$goods.uniformCode",
            商品名称:  "$goods.productName",
            规格: "$goods.standard",
            单价: "$goods.unitPrice",
            数量: "$goods.amount",
//						总价:"$totalGoodsPrice",
						// 发货地址area是个数组,没有拆开,同一个订单的发货地址相同,取数组的第一个元素
						发货地区:{$arrayElemAt: ["$area", 0]}
        }
    }

]);

结果:

相关推荐
未来之窗软件服务9 分钟前
sql速度优化多条合并为一条语句
数据库
山东布谷科技官方12 分钟前
布谷直播源码部署服务器关于数据库配置的详细说明
运维·服务器·数据库·直播系统源码·直播源码·直播系统搭建·直播软件开发
易云码32 分钟前
信息安全建设方案,网络安全等保测评方案,等保技术解决方案,等保总体实施方案(Word原件)
数据库·物联网·安全·web安全·低代码
newxtc37 分钟前
【客观理性深入讨论国产中间件及数据库-科创基础软件】
数据库·中间件·国产数据库·国产中间件·科创
水月梦镜花40 分钟前
redis:list列表命令和内部编码
数据库·redis·list
MonkeyKing_sunyuhua1 小时前
ubuntu22.04 docker-compose安装postgresql数据库
数据库·docker·postgresql
天郁青1 小时前
数据库交互的本地项目:后台管理系统
数据库·交互
马剑威(威哥爱编程)2 小时前
MongoDB面试专题33道解析
数据库·mongodb·面试
小光学长2 小时前
基于vue框架的的流浪宠物救助系统25128(程序+源码+数据库+调试部署+开发环境)系统界面在最后面。
数据库·vue.js·宠物
掘金-我是哪吒2 小时前
微服务mysql,redis,elasticsearch, kibana,cassandra,mongodb, kafka
redis·mysql·mongodb·elasticsearch·微服务