Database
db={"ofertas":[{"_id":1,"nombre_oferta":"Ofe1","ubicacion_puesto":{"pais":"spain","provincia":"pontevedra"}},{"_id":2,"nombre_oferta":"Ofe2","ubicacion_puesto":{"pais":"spain","provincia":"pontevedra"}},{"_id":3,"nombre_oferta":"Ofe3","ubicacion_puesto":{"pais":"spain","provincia":"madrid"}},{"_id":4,"nombre_oferta":"Ofe4","ubicacion_puesto":{"pais":"spain","provincia":"barcelona"}},{"_id":5,"nombre_oferta":"Ofe5","ubicacion_puesto":{"pais":"spain","provincia":"barcelona"}},{"_id":6,"nombre_oferta":"Ofe6","ubicacion_puesto":{"pais":"spain","provincia":""}},{"_id":7,"nombre_oferta":"Ofe7","ubicacion_puesto":{"pais":"spain","provincia":"pontevedra"}},],"candidatos":[{"_id":1,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"pontevedra"}}},{"_id":2,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"pontevedra"}}},{"_id":3,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"pontevedra"}}},{"_id":4,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"pontevedra"}}},{"_id":5,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"madrid"}}},{"_id":6,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"pontevedra"}}},{"_id":7,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":""}}},{"_id":8,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"alicante"}}},{"_id":9,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"zaragoza"}}},{"_id":10,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"cadiz"}}},{"_id":11,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"madrid"}}},{"_id":12,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"madrid"}}},{"_id":13,"que_busco":{"ubicacion_puesto_trabajo":{"provincia":"barcelona"}}},]}
Query
db.candidatos.aggregate([{"$group":{_id:"$que_busco.ubicacion_puesto_trabajo.provincia",countProvinciaCandidato:{$sum:1}}},{$lookup:{from:"ofertas",let:{},pipeline:[{"$group":{_id:"$ubicacion_puesto.provincia",countProvinciaOferta:{$sum:1}}}],as:"ofertas"}},{$project:{_id:1,countProvinciaCandidato:1,countOfertas:{"$reduce":{"input":"$ofertas",initialValue:0,"in":{$cond:[{$eq:["$$this._id","$_id"]},{$add:["$$value",1]},"$$value"]}}}}},{$sort:{"countProvinciaCandidato":-1}},{$limit:20}])