聚合的方法介紹-創(chuàng)新互聯(lián)

聚合( Aggregation )為集合文檔數(shù)據(jù)提供各種處理數(shù)據(jù)方法,并返回計(jì)算結(jié)果。MongoDB 提供了3 種方式來(lái)執(zhí)行聚合命令:聚合管道方法、map-reduce 方法和單一目標(biāo)聚合方法。

創(chuàng)新互聯(lián)服務(wù)緊隨時(shí)代發(fā)展步伐,進(jìn)行技術(shù)革新和技術(shù)進(jìn)步,經(jīng)過(guò)十多年的發(fā)展和積累,已經(jīng)匯集了一批資深網(wǎng)站策劃師、設(shè)計(jì)師、專(zhuān)業(yè)的網(wǎng)站實(shí)施團(tuán)隊(duì)以及高素質(zhì)售后服務(wù)人員,并且完全形成了一套成熟的業(yè)務(wù)流程,能夠完全依照客戶(hù)要求對(duì)網(wǎng)站進(jìn)行成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、建設(shè)、維護(hù)、更新和改版,實(shí)現(xiàn)客戶(hù)網(wǎng)站對(duì)外宣傳展示的首要目的,并為客戶(hù)企業(yè)品牌互聯(lián)網(wǎng)化提供全面的解決方案。

1.聚合管道方法
聚合管道方法又可以直接理解為合計(jì)流水線(xiàn)法,就是把集合里若干含數(shù)值型的文檔記錄,其鍵對(duì)應(yīng)的值進(jìn)行各種分類(lèi)統(tǒng)計(jì)。該方法支持分片集合操作。

語(yǔ)法: db.collection_name.aggregate(
    [{$match: {<field>}},//統(tǒng)計(jì)查找條件
        {$group:{<fieldl >,< field2 >}}
        //fieldl 為分類(lèi)字段; field2 為含各種統(tǒng)計(jì)操作符的數(shù)值型字段,如$sum、$avg、$min、$max、$push、$addToSet、$first、$last操作符


db.Sale_detail.aggregate(
    [
        {
            $match: {ok : false}  //查找條件,與find()的查找條件使用方法一樣
        },
        {
            $group: {
                _id: "$goodsid",
                total: {$sum: "$amount"}  //按goodsid分類(lèi)統(tǒng)計(jì)amount字段的總數(shù)量
            }
        }
    ]
)

_id :"$goodsid" ,goodsid為分類(lèi)字段名,_id為必須指定唯一性字段,不能改為其他名稱(chēng)的字段;total為統(tǒng)計(jì)結(jié)果字段名,可以是任意的符合起名規(guī)則的新名稱(chēng)。$sum為求和操作符號(hào), $amount為求和字段,必須加上雙引號(hào)。

2. map-reduce方法

語(yǔ)法: db.collection_name. mapreduce(
                function() {emit( <this.field1>,<this.field2>)},
               function(key, value){return array.sum(values)},
                {query: {<field>} ,out:<"resultname">}

命令說(shuō)明:

    function(){emit(<this.field1>, <this.field2>)},把集合對(duì)應(yīng)的字段<field1><field2>進(jìn)行map(影射)操作。

    把自field1值和求得值連同out:<"resultname">一起返回。

    query:{<field>}在集合里查詢(xún)符合<field>條件的文檔。
    該方式進(jìn)行聚合運(yùn)算,效率較聚合管道方式要低,而且使用更復(fù)雜。

3. 單一目標(biāo)聚合方法
該方法下,目前有兩種聚合操作功能:db.collection_name.count()和db.collection_name.distinct()。
(1)語(yǔ)法:db.collection_name.count(query, options)
命令說(shuō)明:統(tǒng)計(jì)集合里符合查詢(xún)條件的文檔數(shù)量, query 為查詢(xún)條件, option 參數(shù)詳細(xì)說(shuō)明如表

聚合的方法介紹

統(tǒng)計(jì)符合條件的記錄數(shù)

db.Sale_detail.count({ok: false})


從第二條開(kāi)始統(tǒng)計(jì)符合條件的記錄數(shù)

db.Sale_detail.count({ok: false}, {skip: 1})

統(tǒng)計(jì)指定鍵的不同值并返回不同值

db.Sale_detail.distinct("goodsid")

單一目標(biāo)聚合方法,可以直接在find()后加點(diǎn)使用。
如goodsdb.Sale_detail.find({ok:false}).count()
goodsdb.Sale_detail.find({ok:false}).count().skip(1)

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線(xiàn),公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。

新聞名稱(chēng):聚合的方法介紹-創(chuàng)新互聯(lián)
當(dāng)前URL:http://bm7419.com/article38/iphsp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營(yíng)銷(xiāo)推廣、定制網(wǎng)站靜態(tài)網(wǎng)站、網(wǎng)站策劃、Google、關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)

網(wǎng)站設(shè)計(jì)公司知識(shí)