Database

[{"RecordId":1,"CurrentState":{"collection_method":"Phone","collection_method_convert":1,"any_amount_outside_of_min_max_fx_margin":null,"amounts_and_rates":[{"_id":ObjectId("5ef870670000000000000000"),"amount_from":1000.0,"time_collected_researcher_input":null,"date_collected_researcher_input":null,"timezone_researcher_input":null,"datetime_collected_utc":ISODate("2020-03-02T21:45:00.000Z"),"interbank_rate":0.58548,"ib_api_url":null,"fx_rate":0.56796,"fx_margin":2.9924164787866,"amount_margin_approved":true,"outside_of_min_max_fx_margin":null,"amount_duplicated":false,"fx_margin_delta_mom":null,"fx_margin_reldiff_pct_mom":null,"fx_margin_reldiff_gt15pct_mom":null},{"_id":ObjectId("5efdadae0000000000000000"),"amount_from":10000.0,"time_collected_researcher_input":null,"time_collected_researcher_input1":null,"date_collected_researcher_input":null,"timezone_researcher_input":null,"datetime_collected_utc":ISODate("2020-03-02T21:45:00.000Z"),"interbank_rate":0.58548,"ib_api_url":null,"fx_rate":0.57386,"fx_margin":1.9846963175514,"amount_margin_approved":true,"outside_of_min_max_fx_margin":null,"amount_duplicated":false,"fx_margin_delta_mom":null,"fx_margin_reldiff_pct_mom":null,"fx_margin_reldiff_gt15pct_mom":null}]}},{"RecordId":2,"CurrentState":{"collection_method":"Phone","collection_method_convert":1,"any_amount_outside_of_min_max_fx_margin":null,"amounts_and_rates":[{"_id":ObjectId("5ef870670000000000000000"),"amount_from":1000.0,"time_collected_researcher_input":null,"date_collected_researcher_input":null,"timezone_researcher_input":null,"datetime_collected_utc":ISODate("2020-03-02T21:45:00.000Z"),"interbank_rate":0.58548,"ib_api_url":null,"fx_rate":0.56796,"fx_margin":2.9924164787866,"amount_margin_approved":true,"outside_of_min_max_fx_margin":null,"amount_duplicated":false,"fx_margin_delta_mom":null,"fx_margin_reldiff_pct_mom":null,"fx_margin_reldiff_gt15pct_mom":null,"fx_margin_reldiff_pct_mom1":null,"fx_margin_reldiff_gt15pct_mom1":null},{"_id":ObjectId("5efdadae0000000000000000"),"amount_from":10000.0,"time_collected_researcher_input":null,"time_collected_researcher_input1":null,"date_collected_researcher_input":null,"timezone_researcher_input":null,"datetime_collected_utc":ISODate("2020-03-02T21:45:00.000Z"),"interbank_rate":0.58548,"ib_api_url":null,"fx_rate":0.57386,"fx_margin":1.9846963175514,"amount_margin_approved":true,"outside_of_min_max_fx_margin":null,"amount_duplicated":false,"fx_margin_delta_mom":null,"fx_margin_reldiff_pct_mom":null,"fx_margin_reldiff_gt15pct_mom":null}]}}]

Query

db.collection.aggregate([{$unwind:"$CurrentState.amounts_and_rates"},{"$project":{"RecordId":1,"arrayofkeyvalue":{$size:{"$objectToArray":"$CurrentState.amounts_and_rates"}}}},{$group:{_id:"$RecordId",RecordId:{$first:"$RecordId"},number_of_fields:{$push:{$sum:"$arrayofkeyvalue"}},total:{$sum:"$arrayofkeyvalue"}}},{$project:{_id:0}}])

Result