繁体   English   中英

mongoose 嵌套数组过滤器

[英]mongoose nested array filter

我有一个类似于此的文档表格

{
  "doc-id":2,
  "interfaces": [
    {
     
      "interface-role": "ON",
      "port-nb": 1
    },
    {
      
      "interface-role": "OFF",
      "port-nb": 2
    },
    {
      
      "interface-role": "ON",
      "port-nb": 3
    },
    {
      "interface-role": "OFF",
      "port-nb": 3
    }
  ]
}

我想查询和获取特定的文档界面,并且还能够过滤 ON 和 OFF,这就是我到目前为止所做的尝试

   const doc = await this.doc
        .findOne({
          'doc-id': docId,
          'interfaces["interface-role"]': interfaceRole, //ON or OFF
        })
        .select({ interfaces: 1, _id: 0 })
        .exec();

所以我想要的结果是,如果没有针对接口角色的过滤器,并且如果有一个,则获取接口

您可以使用$or通过$filter进行条件过滤。

db.collection.aggregate([
  {
    $match: {
      "doc-id": 2
    }
  },
  {
    "$addFields": {
      "interfaces": {
        "$filter": {
          "input": "$interfaces",
          "as": "i",
          "cond": {
            $or: [
              {
                $eq: [
                  null,
                  <interfaceRole>
                ]
              },
              {
                $eq: [
                  "$$i.interface-role",
                  <interfaceRole>
                ]
              }
            ]
          }
        }
      }
    }
  }
])

这是未提供interfaceRole时的Mongo 游乐场

这是提供interfaceRole时的Mongo playground

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM