服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - MongoDB - MongoDB聚合功能浅析

MongoDB聚合功能浅析

2020-04-25 17:19shichen2014 MongoDB

这篇文章主要介绍了MongoDB聚合功能,需要的朋友可以参考下

MongoDB数据库功能强大!除了基本的查询功能之外,还提供了强大的聚合功能。这里简单介绍一下count、distinct和group。

1.count:
    

?
1
2
3
4
5
6
7
8
9
10
11
12
13
--在空集合中,count返回的数量为0。
  > db.test.count()
  0
  --测试插入一个文档后count的返回值。
  > db.test.insert({"test":1})
  > db.test.count()
  1
  > db.test.insert({"test":2})
  > db.test.count()
  2
  --count和find一样,也接受条件。从结果可以看出,只有符合条件的文档参与了计算。
  > db.test.count({"test":1})
  1

    
2.distinct:
    distinct用来找出给定键的所有不同的值。使用时也必须指定集合和键。
   

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
--为了便于后面的测试,先清空测试集合。
  > db.test.remove()
  > db.test.count()
  0
  --插入4条测试数据。请留意Age字段。
  > db.test.insert({"name":"Ada", "age":20})
  > db.test.insert({"name":"Fred", "age":35})
  > db.test.insert({"name":"Andy", "age":35})
  > db.test.insert({"name":"Susan", "age":60})
  --distinct命令必须指定集合名称,如test,以及需要区分的字段,如:age。
  --下面的命令将基于test集合中的age字段执行distinct命令。
  > db.runCommand({"distinct":"test", "key":"age"})
  {
      "values" : [
          20,
          35,
          60
      ],
      "stats" : {
          "n" : 4,
          "nscanned" : 4,
          "nscannedObjects" : 4,
          "timems" : 0,
          "cursor" : "BasicCursor"
      },
      "ok" : 1
  }

3.group:
    group做的聚合有些复杂。先选定分组所依据的键,此后MongoDB就会将集合依据选定键值的不同分成若干组。然后可以通过聚合每一组内的文档,产生一个结果文档。
   

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
--这里是准备的测试数据
  > db.test.remove()
  > db.test.insert({"day" : "2012-08-20", "time" : "2012-08-20 03:20:40", "price" : 4.23})
  > db.test.insert({"day" : "2012-08-21", "time" : "2012-08-21 11:28:00", "price" : 4.27})
  > db.test.insert({"day" : "2012-08-20", "time" : "2012-08-20 05:00:00", "price" : 4.10})
  > db.test.insert({"day" : "2012-08-22", "time" : "2012-08-22 05:26:00", "price" : 4.30})
  > db.test.insert({"day" : "2012-08-21", "time" : "2012-08-21 08:34:00", "price" : 4.01})
  --这里将用day作为group的分组键,然后取出time键值为最新时间戳的文档,同时也取出该文档的price键值。
  > db.test.group( {
  ... "key" : {"day":true},      --如果是多个字段,可以为{"f1":true,"f2":true}
  ... "initial" : {"time" : "0"},    --initial表示$reduce函数参数prev的初始值。每个组都有一份该初始值。
  ... "$reduce" : function(doc,prev) { --reduce函数接受两个参数,doc表示正在迭代的当前文档,prev表示累加器文档。
  ...   if (doc.time > prev.time) {
  ...     prev.day = doc.day
  ...     prev.price = doc.price;
  ...     prev.time = doc.time;
  ...   }
  ... } } )
  [
    {
      "day" : "2012-08-20",
      "time" : "2012-08-20 05:00:00",
      "price" : 4.1
    },
    {
      "day" : "2012-08-21",
      "time" : "2012-08-21 11:28:00",
      "price" : 4.27
    },
    {
      "day" : "2012-08-22",
      "time" : "2012-08-22 05:26:00",
      "price" : 4.3
    }
  ]
  --下面的例子是统计每个分组内文档的数量。
  > db.test.group( {
  ... key: { day: true},
  ... initial: {count: 0},
  ... reduce: function(obj,prev){ prev.count++;},
  ... } )
  [
    {
      "day" : "2012-08-20",
      "count" : 2
    },
    {
      "day" : "2012-08-21",
      "count" : 2
    },
    {
      "day" : "2012-08-22",
      "count" : 1
    }
  ]
  --最后一个是通过完成器修改reduce结果的例子。
  > db.test.group( {
  ... key: { day: true},
  ... initial: {count: 0},
  ... reduce: function(obj,prev){ prev.count++;},
  ... finalize: function(out){ out.scaledCount = out.count * 10 } --在结果文档中新增一个键。
  ... } )
  [
    {
      "day" : "2012-08-20",
      "count" : 2,
      "scaledCount" : 20
    },
    {
      "day" : "2012-08-21",
      "count" : 2,
      "scaledCount" : 20
    },
    {
      "day" : "2012-08-22",
      "count" : 1,
      "scaledCount" : 10
    
  ]

 

延伸 · 阅读

精彩推荐
  • MongoDBMongodb实现定时备份与恢复的方法教程

    Mongodb实现定时备份与恢复的方法教程

    这篇文章主要给大家介绍了Mongodb实现定时备份与恢复的方法教程,文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面...

    chenjsh364522020-05-13
  • MongoDBMongoDB凭什么跻身数据库排行前五

    MongoDB凭什么跻身数据库排行前五

    MongoDB以比去年同期超出65.96分的成绩继续雄踞榜单前五,这个增幅在全榜仅次于PostgreSQL的77.99,而其相对于4月份的6.10分的增长也是仅次于微软SQL Server排名...

    孙浩峰3892020-05-22
  • MongoDBMongoDB 内存使用情况分析

    MongoDB 内存使用情况分析

    都说 MongoDB 是个内存大户,但是怎么知道它到底用了多少内存呢...

    MongoDB教程网10002020-09-29
  • MongoDBMongoDB中javascript脚本编程简介和入门实例

    MongoDB中javascript脚本编程简介和入门实例

    作为一个数据库,MongoDB有一个很大的优势——它使用js管理数据库,所以也能够使用js脚本进行复杂的管理——这种方法非常灵活 ...

    MongoDB教程网6982020-04-24
  • MongoDBmongodb基本命令实例小结

    mongodb基本命令实例小结

    这篇文章主要介绍了mongodb基本命令,结合实例形式总结分析了MongoDB数据库切换、查看、删除、查询等基本命令用法与操作注意事项,需要的朋友可以参考下...

    dawn-liu3652020-05-26
  • MongoDB迁移sqlserver数据到MongoDb的方法

    迁移sqlserver数据到MongoDb的方法

    这篇文章主要介绍了迁移sqlserver数据到MongoDb的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...

    听枫xl9682021-01-03
  • MongoDB分布式文档存储数据库之MongoDB分片集群的问题

    分布式文档存储数据库之MongoDB分片集群的问题

    这篇文章主要介绍了分布式文档存储数据库之MongoDB分片集群的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...

    Linux-18743072020-12-20
  • MongoDBMongoDB安装图文教程

    MongoDB安装图文教程

    这篇文章主要为大家详细介绍了MongoDB安装图文教程,分为两大部分为大家介绍下载MongoDB和安装MongoDB的方法,感兴趣的小伙伴们可以参考一下 ...

    Yangyi.He6132020-05-07