Możesz użyć poniższej agregacji
db.collection.aggregate([
{ "$project": {
"difference": {
"$divide": [
{ "$subtract": ["$logoutTime", "$loginTime"] },
60 * 1000 * 60
]
}
}},
{ "$group": {
"_id": "$studentID",
"totalDifference": { "$sum": "$difference" }
}},
{ "$match": { "totalDifference": { "$gte": 20 }}}
])
Musisz tylko $subtract
loginTime
z logoutTime
i da ci odjęty znacznik czasu, a następnie po prostu $divide
to z 3600000
aby uzyskać czas w godzinach.