mongo 聚合查询 关联查询

 

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

未完待续!

  

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值