Database
db={"gateway":[{"_id":"18001887","mac_id":"18001887","group_id":"0"},{"_id":"18001888","mac_id":"18001888","group_id":"1"},{"_id":"18001889","mac_id":"18001889","group_id":"0"}],"commands":[{"_id":ObjectId("615581dcb9ebca6c37eb39e4"),"org_id":0,"mac_id":"18001887","config":{"user_info":[{"user_id":1,"user_pwd":"123456","mapped_id":1},{"user_id":2,"user_pwd":"123123","mapped_id":3}]}},{"_id":ObjectId("615581dcb9ebca6c37eb39e5"),"org_id":0,"mac_id":"18001889","config":{"slave_id":1}}]}
Query
db.gateway.aggregate([{$match:{group_id:"0"}},{$project:{_id:0,mac_id:1}},{$lookup:{from:"commands",localField:"mac_id",foreignField:"mac_id",as:"childs"}},{$project:{mac_id:1,childs:{$filter:{"input":"$childs","as":"child","cond":{"$in":[1,{$ifNull:["$$child.config.user_info.mapped_id",[]]}]}}}}}])