03_mongoDB的聚合基于4.2版本

1. 常用管道命令

这里面的管道和Linux里的管道类似,都是通过管道将数据筛选出来传递给下一层处理

  • $group: 将集合中的⽂档分组, 可⽤于统计结果
  • $match: 过滤数据, 只输出符合条件的⽂档
  • $project: 修改输⼊⽂档的结构, 如重命名、 增加、 删除字段、 创建计算结果
  • $sort: 将输⼊⽂档排序后输出
  • $limit: 限制聚合管道返回的⽂档数
  • $skip: 跳过指定数量的⽂档, 并返回余下的⽂档
db.orders.aggregate([
   { $match: { status: "A" } },  # 先匹配出条件文档
   { $group: { _id: "$cust_id", total: { $sum: "$amount" } } }  # 对过滤后的文档分组统计处理
])
# 0. 元数据
> db.test.find().pretty()
{
        "_id" : ObjectId("5f02eb5d17e6e2abe3725347"),
        "user_id" : "aaa",
        "amount" : 100,
        "status" : "A"
}
{
        "_id" : ObjectId("5f02eb5d17e6e2abe3725348"),
        "user_id" : "aaa",
        "amount" : 200,
        "status" : "A"
}
{
        "_id" : ObjectId("5f02eb5d17e6e2abe3725349"),
        "user_id" : "bbb",
        "amount" : 400,
        "status" : "A"
}
{
        "_id" : ObjectId("5f02eb5d17e6e2abe372534a"),
        "user_id" : "aaa",
        "amount" : 100,
        "status" : "B"
}

# 1. 先match过滤数据
> db.test.aggregate({$match:{status:"A"}})

{ "_id" : ObjectId("5f02eb5d17e6e2abe3725347"), "user_id" : "aaa", "amount" : 100, "status" : "A" }
{ "_id" : ObjectId("5f02eb5d17e6e2abe3725348"), "user_id" : "aaa", "amount" : 200, "status" : "A" }
{ "_id" : ObjectId("5f02eb5d17e6e2abe3725349"), "user_id" : "bbb", "amount" : 400, "status" : "A" }


# 2. 管道的作用就是将上一层数据处理后传递给下一层
> db.test.aggregate([
... { $match: {status:"A"} },
... { $group: { _id:"$user_id", total:{$sum:"$amount"} } } # 根据user_id属性分组,计算amount属性的总和
... ]) 

{ "_id" : "bbb", "total" : 400 }
{ "_id" : "aaa", "total" : 300 }

# 通过project对_id进行判断是否输出,其余只要非0即可
> db.test.aggregate({ $project:{_id:0,status:2,user_id:1,amount:1} })
{ "user_id" : "aaa", "amount" : 100, "status" : "A" }
{ "user_id" : "aaa", "amount" : 200, "status" : "A" }
{ "user_id" : "bbb", "amount" : 400, "status" : "A" }
{ "user_id" : "aaa", "amount" : 100, "status" : "B" }

2. 常用表达式命令

  • $sum: 计算总和, $sum:1 表示以⼀倍计数
  • $avg: 计算平均值
  • $min: 获取最⼩值
  • $max: 获取最⼤值
  • $push: 在结果⽂档中插⼊值到⼀个数组中
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值