// 準備測試數(shù)據(jù) db.user.drop(); for(var i=10; i 100; i++) { db.user.insert({ name:"user" + i, age : Math.floor(Math.random()*10)+ 20, sex : Math.floor(Math.random()*3)%2 ==0 ? 'M' : 'F', chinese : Math.floor(Math.random()*50)+50, math : Math.floor(Math.random()*50)+50, english : Math.floor(Math.random()*50)+50, class : "C" + i%5 }) } // group函數(shù) // 按照class進行分組,顯示每個class中的用戶姓名和性別 db.user.group({ key: {"class": true}, initial: {"person": []}, reduce: function(cur, prev) { prev.person.push({name: cur.name, sex: cur.sex, age: cur.age}); } }); // 對age>25的用戶,按照class進行分組,顯示每個class中的用戶姓名和性別,并統(tǒng)計每組的人數(shù) db.user.group({ key: {"class": true}, initial: {"person": []}, reduce: function(doc, out){ out.person.push({name: doc.name, sex: doc.sex, age: doc.age}); }, finalize: function(out){ out.count = out.person.length; }, condition: {"age": {$gt: 25}} }) // 分組計算每個class中,chinese最大值和最小值 db.user.group({ key: {"class": true}, initial: {"chinese_min": 0, "chinese_max":0 }, reduce: function(doc, out){ out.chinese_min = doc.chinese; out.chinese_min = doc.chinese; out.chinese_min = Math.min(out.chinese_min, doc.chinese); out.chinese_max = Math.max(out.chinese_max, doc.chinese) }, }) // 利用分組,計算每個總成績和成績平均值 db.user.group({ key: {"_id" : true}, initial: {name:"", total: 0, avg: 0}, reduce: function(doc, out){ out.name = doc.name; out.total = doc.chinese + doc.math + doc.english; out.avg = Math.floor(out.total / 3); } })
group參數(shù)選項:
1.key: 這個就是分組的key
2.initial: 每組都分享一個初始化函數(shù),特別注意:是每一組initial函數(shù)。
3.reduce: 這個函數(shù)的第一個參數(shù)是當前的文檔對象,第二個參數(shù)是上一次function操作的累計對象。有多少個文檔, $reduce就會調(diào)用多少次。
4.condition: 這個就是過濾條件。
5.finalize: 這是個函數(shù),每一組文檔執(zhí)行完后,多會觸發(fā)此方法。
標簽:吉安 鶴崗 昭通 本溪 邯鄲 丹東 大理 景德鎮(zhèn)
巨人網(wǎng)絡通訊聲明:本文標題《MongoDB學習筆記之分組(group)使用示例》,本文關鍵詞 MongoDB,學習,筆記,之,分組,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。