MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Mongodb, grouper par datediff et obtenir l'heure

D'après ce que j'ai compris dans votre question (vous devez en fait fournir quelques exemples de documents avec votre schéma) si votre Traitement modèle a la structure suivante, par exemple :

/* 0 */
{
    "_id" : 1,
    "user" : "abc",
    "dateEntre" : ISODate("2014-03-01T08:00:00.000Z"),
    "dateSortie" : ISODate("2014-03-01T13:00:00.000Z")
}

/* 1 */
{
    "_id" : 2,
    "user" : "jkl",
    "dateEntre" : ISODate("2014-03-01T08:00:00.000Z"),
    "dateSortie" : ISODate("2014-03-01T10:30:00.000Z")
}
/* 2 */
{
    "_id" : 3,
    "user" : "jkl",
    "dateEntre" : ISODate("2014-03-01T12:00:00.000Z"),
    "dateSortie" : ISODate("2014-03-01T18:00:00.000Z")
}

Votre framework d'agrégation aurait un seul $project opération de pipeline où vous obtenez la différence entre les deux dates en utilisant le $subtract opérateur, puis transformez cette différence de date en millisecondes en heures en utilisant le $divide opérateur. La dernière étape de votre pipeline consistera à utiliser le $group opérateur pour regrouper les documents du pipeline précédent et $sum les heures de différence de date :

Traitement.aggregate([ 
    { 
        $project: { 
            user: 1,             
            dateDifference: { 
                $divide: [{ 
                    $subtract: [ "$dateSortie", "$dateEntre" ]
                    }, 1000*60*60
                ] 
            }
         }
    },
    { 
        $group: { 
            _id: "$user",             
            total : { 
                $sum : "$dateDifference"
            }
        }
    } 
])

Résultats :

/* 0 */
{
    "result" : [ 
        {
            "_id" : "jkl",
            "total" : 8.5
        }, 
        {
            "_id" : "abc",
            "total" : 5
        }
    ],
    "ok" : 1
}