MongoDB的分組統計 group

來源:互聯網
上載者:User

標籤:style   blog   http   io   color   ar   使用   java   sp   

mongodb中的分組彙總用$group,它是不能進行sort的,使用格式如下:

{ $group: { _id: <expression>, <field1>: { <accumulator1> : <expression1> }, ... } }

其中_id屬性是必須要有的,目的是用來指定分組的欄位或依據,field1為自訂欄位,accumulator為累加器,下面以統計每天使用者註冊數為列

db.user.aggregate([    {        $group:{            _id:{                year:{$year:"$time"},//time為註冊時間 $year表示擷取年份                month:{$month:"$time"},//$month擷取月份                day:{$dayOfMonth:"$time"}//$dayOfMonth擷取多少號            }            count:{$sum:1}//$sum為累計,1表示累加數        }    }])

如果只想註冊地區為四川的則在$goup前增加一個$match:

{    $match:{         location:"SiChuan"    }},

以上兩個彙總操作的java實現方式:

DBObject filterCond = new BasicDBObject();filterCond.put("location", "SiChuan");DBObject match = new BasicDBObject("$match", filterCond);DBObject group = new BasicDBObject();DBObject groupDate = new BasicDBObject();groupDate.put("year", new BasicDBObject("$year", "$time"));groupDate.put("month", new BasicDBObject("$month", "$time"));groupDate.put("day", new BasicDBObject("$dayOfMonth", "$time"));group.put("$group", new BasicDBObject("_id", groupDate));
AggregationOutput output = coll.aggregate(match, group); Iterator iterator = output.results().iterator();

 

第一次寫部落格,才發現語言群組織能力真差,累死了,下班~~~

更多的彙總操作請參見這》》》http://docs.mongodb.org/manual/reference/operator/aggregation-pipeline/

 

MongoDB的分組統計 group

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.