Requête somme MongoDb

, Par exemple j'ai les données suivantes dans MongoDB:

{ "_id" : ObjectId("524091f99c49c4c3f66b0e46"), "hour" : 10, "incoming", 100}
{ "_id" : ObjectId("5240a045dbeff33c7333aa51"), "hour" : 11, "incoming", 200}
{ "_id" : ObjectId("5240a2ecda0d37f35c618aca"), "hour" : 12, "incoming", 300}

Maintenant, je veux interroger " additionner le nombre d'entrants entre 11 et 12 "(le résultat devrait être 500), Comment pourrais-je le faire en utilisant Mongo Shell?

29
demandé sur user2597504 2013-09-24 02:24:57

1 réponses

Comme llovet l'a suggéré, le cadre d'agrégation est la voie à suivre. Voici à quoi ressemblerait votre requête:

db.CollectionNameGoesHere.aggregate({ $match: {
    $and: [
        { hour: { $gte: 11 } },
        { hour: { $lte: 12 } }
    ]
} },
{ $group: { _id : null, sum : { $sum: "$incoming" } } });

Vous pouvez également façonner le document résultant pour ne contenir que la somme en ajoutant un opérateur $ project à la fin du pipeline, comme ceci:

{ $project: { _id: 0, sum: 1 } }
45
répondu jamshehan 2013-09-24 15:27:32