一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫(kù)技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫(kù) - MongoDB - MongoDB聚合功能淺析

MongoDB聚合功能淺析

2020-04-25 17:19shichen2014 MongoDB

這篇文章主要介紹了MongoDB聚合功能,需要的朋友可以參考下

MongoDB數(shù)據(jù)庫(kù)功能強(qiáng)大!除了基本的查詢功能之外,還提供了強(qiáng)大的聚合功能。這里簡(jiǎn)單介紹一下count、distinct和group。

1.count:
    

?
1
2
3
4
5
6
7
8
9
10
11
12
13
--在空集合中,count返回的數(shù)量為0。
  > db.test.count()
  0
  --測(cè)試插入一個(gè)文檔后count的返回值。
  > db.test.insert({"test":1})
  > db.test.count()
  1
  > db.test.insert({"test":2})
  > db.test.count()
  2
  --count和find一樣,也接受條件。從結(jié)果可以看出,只有符合條件的文檔參與了計(jì)算。
  > db.test.count({"test":1})
  1

    
2.distinct:
    distinct用來(lái)找出給定鍵的所有不同的值。使用時(shí)也必須指定集合和鍵。
   

?
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
--為了便于后面的測(cè)試,先清空測(cè)試集合。
  > db.test.remove()
  > db.test.count()
  0
  --插入4條測(cè)試數(shù)據(jù)。請(qǐng)留意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,以及需要區(qū)分的字段,如:age。
  --下面的命令將基于test集合中的age字段執(zhí)行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做的聚合有些復(fù)雜。先選定分組所依據(jù)的鍵,此后MongoDB就會(huì)將集合依據(jù)選定鍵值的不同分成若干組。然后可以通過(guò)聚合每一組內(nèi)的文檔,產(chǎn)生一個(gè)結(jié)果文檔。
   

?
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
--這里是準(zhǔn)備的測(cè)試數(shù)據(jù)
  > 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鍵值為最新時(shí)間戳的文檔,同時(shí)也取出該文檔的price鍵值。
  > db.test.group( {
  ... "key" : {"day":true},      --如果是多個(gè)字段,可以為{"f1":true,"f2":true}
  ... "initial" : {"time" : "0"},    --initial表示$reduce函數(shù)參數(shù)prev的初始值。每個(gè)組都有一份該初始值。
  ... "$reduce" : function(doc,prev) { --reduce函數(shù)接受兩個(gè)參數(shù),doc表示正在迭代的當(dāng)前文檔,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
    }
  ]
  --下面的例子是統(tǒng)計(jì)每個(gè)分組內(nèi)文檔的數(shù)量。
  > 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
    }
  ]
  --最后一個(gè)是通過(guò)完成器修改reduce結(jié)果的例子。
  > db.test.group( {
  ... key: { day: true},
  ... initial: {count: 0},
  ... reduce: function(obj,prev){ prev.count++;},
  ... finalize: function(out){ out.scaledCount = out.count * 10 } --在結(jié)果文檔中新增一個(gè)鍵。
  ... } )
  [
    {
      "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實(shí)現(xiàn)定時(shí)備份與恢復(fù)的方法教程

    Mongodb實(shí)現(xiàn)定時(shí)備份與恢復(fù)的方法教程

    這篇文章主要給大家介紹了Mongodb實(shí)現(xiàn)定時(shí)備份與恢復(fù)的方法教程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面...

    chenjsh364522020-05-13
  • MongoDBMongoDB憑什么躋身數(shù)據(jù)庫(kù)排行前五

    MongoDB憑什么躋身數(shù)據(jù)庫(kù)排行前五

    MongoDB以比去年同期超出65.96分的成績(jī)繼續(xù)雄踞榜單前五,這個(gè)增幅在全榜僅次于PostgreSQL的77.99,而其相對(duì)于4月份的6.10分的增長(zhǎng)也是僅次于微軟SQL Server排名...

    孫浩峰3892020-05-22
  • MongoDBMongoDB 內(nèi)存使用情況分析

    MongoDB 內(nèi)存使用情況分析

    都說(shuō) MongoDB 是個(gè)內(nèi)存大戶,但是怎么知道它到底用了多少內(nèi)存呢...

    MongoDB教程網(wǎng)10002020-09-29
  • MongoDBMongoDB中javascript腳本編程簡(jiǎn)介和入門(mén)實(shí)例

    MongoDB中javascript腳本編程簡(jiǎn)介和入門(mén)實(shí)例

    作為一個(gè)數(shù)據(jù)庫(kù),MongoDB有一個(gè)很大的優(yōu)勢(shì)——它使用js管理數(shù)據(jù)庫(kù),所以也能夠使用js腳本進(jìn)行復(fù)雜的管理——這種方法非常靈活 ...

    MongoDB教程網(wǎng)6982020-04-24
  • MongoDBmongodb基本命令實(shí)例小結(jié)

    mongodb基本命令實(shí)例小結(jié)

    這篇文章主要介紹了mongodb基本命令,結(jié)合實(shí)例形式總結(jié)分析了MongoDB數(shù)據(jù)庫(kù)切換、查看、刪除、查詢等基本命令用法與操作注意事項(xiàng),需要的朋友可以參考下...

    dawn-liu3652020-05-26
  • MongoDB遷移sqlserver數(shù)據(jù)到MongoDb的方法

    遷移sqlserver數(shù)據(jù)到MongoDb的方法

    這篇文章主要介紹了遷移sqlserver數(shù)據(jù)到MongoDb的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下...

    聽(tīng)楓xl9682021-01-03
  • MongoDB分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB分片集群的問(wèn)題

    分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB分片集群的問(wèn)題

    這篇文章主要介紹了分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB分片集群的問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋...

    Linux-18743072020-12-20
  • MongoDBMongoDB安裝圖文教程

    MongoDB安裝圖文教程

    這篇文章主要為大家詳細(xì)介紹了MongoDB安裝圖文教程,分為兩大部分為大家介紹下載MongoDB和安裝MongoDB的方法,感興趣的小伙伴們可以參考一下 ...

    Yangyi.He6132020-05-07
主站蜘蛛池模板: 亚洲国产精品自在现线让你爽 | 国产成人久久精品一区二区三区 | 99精品影院 | 欧美摘花破处 | 精品一二三区久久AAA片 | 精品成人一区二区三区免费视频 | 男女性gif抽搐出入视频 | 国产剧情麻豆刘玥视频 | 成人性生交大片免费看软件 | 亚洲男人天堂网址 | 四虎在线最新永久免费 | 校草让我脱了内裤给全班看 | kkkk4444在线看片免费 | 双性总裁(h) | 国产精品原创视频 | 久久这里只有精品视频9 | 亚洲欧美日韩另类精品一区二区三区 | 亚洲成人网在线 | 教师波多野结衣在线播放 | 精品牛牛影视久久精品 | 国产爽视频 | 俄罗斯bbbbbbbbb大片 | 日日干影院 | 窝窝午夜精品一区二区 | 男女全黄h全肉细节文 | 色噜噜亚洲男人的天堂www | 国产三级精品三级男人的天堂 | 天美传媒传媒免费观看 | 人体做爰aaaa免费 | 国产良心大作白丝精厕 | 99任你躁精品视频 | 国产麻豆剧果冻传媒观看免费视频 | 国产一区二区三区日韩 | 亚洲无线一二三四区 | 好吊操这里有精品 | 欧美亚洲免费 | 国产网站免费观看 | 天天排行网 | 国内精品视频一区二区三区 | 日本视频高清 | 视频一区二区国产无限在线观看 |