Database

[{"book":{"title":"Book1","author":"Tom"},"quantity":3},{"book":{"title":"Book2","author":"Tom"},"quantity":4},{"book":{"title":"Book3","author":"Dick"},"quantity":9},{"book":{"title":"Book4","author":"Harry"},"quantity":6},{"book":{"title":"Book5","author":"Chris"},"quantity":7},{"book":{"title":"Book6","author":"Dick"},"quantity":10}]

Query

db.collection.aggregate([{$group:{_id:"$book.author",books:{$push:{title:"$book.title",quantity:"$quantity"}}}},{$project:{"name":"$_id","books":1,"_id":0}}])

Result