mongo连表查询

本文介绍了如何在MongoDB中进行连表查询,以高效验证数据是否已存入相关数据库。传统方法需要在person表中查找face_id,然后在feature_repository表中匹配feature_id和repo_id。通过MongoDB的连表查询,可以一次性获取所需信息,避免多次手动操作。内容包括将多face_id记录拆分为多个记录,并添加name字段以优化展示效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景:

  • 目的验证数据是否入到相关库中
  • 手动方法:先在person表中,找到face_id;拿fece_id到feature_repository表中,找到对应的feature_id,以及repo_id;最后验证是否有feature_id,repo_id是否是3

连表查询,一次查询到位,不用多个表手动copy:

  • 连表查询,feature_repository  left join  perso
    db.feature_repository.aggregate([{
     $lookup:{
     from:"person",
     localField:"feature_id",
     foreignField:"face_list.face_id",
     as:"f"
     }
    }
    ])
    
    

  •  拆分:把有多个face_id的person ,拆分成多个record
    db.feature_repository.aggregate([{
     $lookup:{
     from:"person",
     localField:"feature_id",
     foreignField:"face_list.face_id",
     as:"f"
     }
    },{ 
     $unwind: "$f"
    }
    ])

  • 在一级关系中,新增字段name,便于后面展示
    db.feature_repository.aggregate([{
     $lookup:{
     from:"person",
     localField:"feature_id",
     foreignField:"face_list.face_id",
     as:"f"
     }
    },{ 
     $unwind: "$f"
    },{
     $addFields:{name: "$f.person_information.name"}
    }
    ])

  • 展示想要的字段,1展示 0不展示
    db.feature_repository.aggregate([{
     $lookup:{
     from:"person",
     localField:"feature_id",
     foreignField:"face_list.face_id",
     as:"f"
     }
    },{ 
     $unwind: "$f"
    },{
     $addFields:{name: "$f.person_information.name"}
    },{
     $project:{
     feature_id:1,
     name:1
     }
    }
    ])

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值