1.$match 数据过滤类似于mysql中的 where 及 having 对文档数据状态进行状态过滤(100, -100) 关键字($match)
db.getCollection('account').aggregate([
{"$match":{"state":{"$in":[100, -100]}}}, {"$group": {"_id": "$gid"}}
])
2.mongo $group 分组后显示【多个字段】 关键字($group)
db.getCollection('account').aggregate([
{"$group":{"_id":{"name": "$name","gid":"$gid","value":"$value"}}}
])
3.聚合文档中 所有gid的总合 关键字($group,$sum)
db.getCollection('account').aggregate([
{"$group":{"_id":null,"gid":{"$sum":"$gid"}}}
])
计算 文档中去重后的gid 出现次数
db.getCollection('account').aggregate([
{"$group":{"_id": "$gid", "count": {"$sum": 1}}}
])
4.获取文档中gid的平均值关键字($group,$avg)
db.getCollection('account').aggregate([
{"$group":{"_id":null,"gid":{"$avg":"$gid"}}}
])
5 获取 文档中 gid最大最小值 把平均值$avg 替换$max或$min
6. mongo 关联查询 (亲测有效)
db.getCollection('app_key').aggregate([
{"$lookup": {
"from": "app",
"localField": "app_id",
"foreignField": "_id",
"as": "datas"
}
}
])
1. from: "要连接的表",
2. localField: "当前Collection中需要连接的字段",
3. foreignField: "外连Collection中连接查询的字段",
4. as: "把获取到的的值赋值给这个字段
7. 先按gid分组,分完组之后将name属性映射到数组中
db.getCollection('account').aggregate([
{"$group": {"_id": "$gid", "name_list": {"$push": "$name"}}}
])
8. 按gid 分组, $push把所有重复gid的name 放入name_list中, $sum:1,计算gid重复次数,$sum": "$gid",计算gid重复的总数
$unwind 把每文档中每条数据中name_list中拆分成单条文档, 条件字段保留
db.getCollection('account').aggregate([
{"$group":{"_id": "$gid", "name_list": {"$push": "$name"}, "count": {"$sum": 1}, "total": {"$sum": "$gid"}}},
{"$unwind": "$name_list"}
])
如果以上不满足 访问这里
https://blog.csdn.net/zhanjianshinian/article/details/84632745
未完待续!