yewanji 2023-01-07 08:59 采纳率: 35.8%
浏览 47
已结题

mongodb 嵌套查询如何过滤掉不符合条件的数据

假如有一个年级集合。年级下面有很多学生

[
  {
    "_id": "1",
    "gradeName": "一年级",
    "students": [
      {
        "name": "张三",
        "age": "18"
      },
      {
        "name": "张三丰",
        "age": "88"
      },
      {
        "name": "李四"
      }
    ]
  },
  {
    "_id": "2",
    "gradeName": "二年级",
    "students": [
      {
        "name": "老王",
        "age": "18"
      },
      {
        "name": "老李",
        "age": "88"
      },
      {
        "name": "老张",
        "age": 28
      }
    ]
  }
]

我想查询姓张的同学的所有年级,且子集里面只包含姓张的同学
期待的返回结果如下

{
    "_id": "1",
    "gradeName": "一年级",
    "students": [
      {
        "name": "张三",
        "age": "18"
      },
      {
        "name": "张三丰",
        "age": "88"
      }
    ]
  }

  • 写回答

5条回答 默认 最新

  • 阳光宅男xxb 2023-01-07 09:07
    关注

    方法一:使用$unwind将数组打散,获取结果集后用$match筛选符合条件的数据,最后使用$group进行聚合获取最终结果集。
    方法二:使用$match过滤符合条件的根文档结果集,然后使用$project返回对应字段的同时,在数组中使用$filter进行内部过滤,返回最终结果集

    这个文章很适合你:https://www.51sjk.com/b91b129138/

    望采纳,望采纳!祝你的问题早日解决!!!!!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 1月15日
  • 已采纳回答 1月7日
  • 创建了问题 1月7日

悬赏问题

  • ¥15 cocos的js代码调用wx.createUseInfoButton问题!
  • ¥15 关于自相关函数法和周期图法实现对随机信号的功率谱估计的matlab程序运行的问题,请各位专家解答!
  • ¥15 Python程序,深度学习,有偿私
  • ¥15 扫描枪扫条形码出现问题
  • ¥35 poi合并多个word成一个新word,原word中横版没了.
  • ¥15 【火车头采集器】搜狐娱乐这种列表页网址,怎么采集?
  • ¥15 求MCSCANX 帮助
  • ¥15 机器学习训练相关模型
  • ¥15 Todesk 远程写代码 anaconda jupyter python3
  • ¥15 我的R语言提示去除连锁不平衡时clump_data报错,图片以下所示,卡了好几天了,苦恼不知道如何解决,有人帮我看看怎么解决吗?