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: 在结果⽂档中插⼊值到⼀个数组中