Mudanças entre as edições de "Query de MongoDB agregando por mês e ano"

De Basef
Ir para: navegação, pesquisa
Linha 1: Linha 1:
 +
Segue abaixo como agregar a collection "collection" por mês e ano (pelo campo "createdAt").
 +
 
Query do Mongo:
 
Query do Mongo:
  
Linha 39: Linha 41:
  
 
AggregationOutput output =
 
AggregationOutput output =
     mongo.getCollection(Transaction.collection).aggregate(criteria);
+
     mongo.getCollection("collection").aggregate(criteria);
 
</source>
 
</source>
  
Linha 62: Linha 64:
  
 
AggregationOutput output =
 
AggregationOutput output =
     mongo.getCollection(Transaction.collection).aggregate(criteria);
+
     mongo.getCollection("collection").aggregate(criteria);
 
</source>
 
</source>

Edição das 20h20min de 21 de agosto de 2016

Segue abaixo como agregar a collection "collection" por mês e ano (pelo campo "createdAt").

Query do Mongo:

db.collection.aggregate(
    {$project : {
         year : {$year : "$createdAt"}, 
         month : {$month : "$createdAt"}
    }},
    {$group : {
         _id : {year : "$year", month : "$month"}, 
         count : {$sum : 1}
    }}
)

No Java, com query string:

List criteria = (List) JSON.parse(
    "[" +
        "{ " +
            "$project: { " +
                "year: {$year: \"$createdAt\"}, " +
                "month: {$month: \"$createdAt\"} " +
            "} " +
        "}, " +
        "{ " +
            "$group: { " +
                "_id: { " +
                    "year: \"$year\", " +
                    "month: \"$month\"" +
                "} " +
            "} " +
        "} " +
    "]"
);
 
MongoTemplate mongo = new MongoTemplate(new Mongo("localhost"), "myMongoDb");
 
AggregationOutput output =
    mongo.getCollection("collection").aggregate(criteria);

No Java, utilizando objetos:

List criteria = asList(
    new BasicDBObject("$project",
        new BasicDBObject("year", new BasicDBObject("$year", "$createdAt"))
        .append("month", new BasicDBObject("$month", "$createdAt"))
    ),
    new BasicDBObject("$group",
        new BasicDBObject("_id",
            new BasicDBObject("year", "$year")
            .append("month", "$month")
        )
        .append("count", new BasicDBObject("$sum", 1))
    )
);
 
MongoTemplate mongo = new MongoTemplate(new Mongo("localhost"), "myMongoDb");
 
AggregationOutput output =
    mongo.getCollection("collection").aggregate(criteria);