Database

[{"startTime":{"$date":"2021-10-20T14:29:52.411Z"},"details":{"name":"Scence","title":"Scence 1","description":"desc","enabled":true},"endTime":{"$date":"2021-10-20T14:39:14.001Z"},"group":"one"},{"startTime":{"$date":"2021-10-20T14:29:52.411Z"},"details":{"name":"Scence","title":"Scence 1","description":"desc","enabled":true},"endTime":{"$date":"2021-10-20T14:39:14.001Z"},"group":"one"},{"startTime":{"$date":"2021-10-20T14:29:52.411Z"},"details":{"name":"Scence","title":"Scence 2","description":"desc","enabled":true},"endTime":{"$date":"2021-10-20T14:39:14.001Z"},"group":"one"},{"startTime":{"$date":"2021-10-20T14:29:52.411Z"},"details":{"name":"Scence","title":"Scence 3","description":"desc","enabled":true},"endTime":{"$date":"2021-10-20T14:39:14.001Z"},"group":"one"},{"startTime":{"$date":"2021-10-20T14:29:52.411Z"},"details":{"name":"Scence","title":"Scence 1","description":"desc","enabled":true},"endTime":{"$date":"2021-10-20T14:39:14.001Z"},"group":"two"}]

Query

db.collection.aggregate([{"$project":{_id:0,group:1,details:1,"difference":{"$divide":[{"$subtract":["$endTime","$startTime"]},60000]}}},{"$group":{"_id":"$group","details":{$push:{title:"$details.title",avgtime:{"$sum":"$difference"}}}}}])

Result