主页 > 知识库 > mongodb如何对文档内数组进行过滤的方法步骤

mongodb如何对文档内数组进行过滤的方法步骤

热门标签:老虎洗衣店地图标注 济南电销机器人加盟公司 怎么投诉地图标注 杭州人工电销机器人价格 云南外呼系统 广州长安公司怎样申请400电话 呼和浩特电销外呼系统加盟 苹果汽车租赁店地图标注 电销机器人是什么软件

本文介绍了mongodb如何对文档内数组进行过滤的方法步骤,分享给大家,具体如下:


mongodb文档内包含数组,需要将数组中符合条件的数据过滤出来并返回结果集,可以用两种方式来查询group或filter。
数据源:

{
  "_id" : ObjectId("5bbcc0c9a74db9804e78a157"),
  "uid" : "1000001",
  "name" : "zhangsan",
  "addrs" : [ 
    {
      "is_query" : "1",
      "city" : "北京"
    }, 
    {
      "is_query" : "0",
      "city" : "上海"
    }, 
    {
      "is_query" : "1",
      "city" : "深圳"
    }
  ]
}
{
  "_id" : ObjectId("5bbcc167a74db9804e78a172"),
  "uid" : "1000002",
  "name" : "lisi",
  "addrs" : [ 
    {
      "is_query" : "0",
      "city" : "北京"
    }, 
    {
      "is_query" : "0",
      "city" : "上海"
    }, 
    {
      "is_query" : "1",
      "city" : "深圳"
    }
  ]
}

要求查询指定uid下,addrs数组中只包含is_query等于1的结果集(0的不包含)。

查询语句:

方法一:使用$unwind将addrs数组打散,获取结果集后用$match筛选符合条件的数据,最后使用$group进行聚合获取最终结果集。

db.getCollection('user').aggregate(
  [
    {  
      $unwind: "$addrs" 
    },
    { 
      $match : {
        "uid":"1000001", 
        "addrs.is_query": "1" 
      } 
    },
    { 
      $group : { 
        "_id" : "$uid", 
        "addrs": { $push: "$addrs" } 
      } 
    } 
  ]
)

Result:

{
  "_id" : "1000001",
  "addrs" : [ 
    {
      "is_query" : "1",
      "city" : "北京"
    }, 
    {
      "is_query" : "1",
      "city" : "深圳"
    }
  ]
}

方法二:使用$match过滤符合条件的根文档结果集,然后使用$project返回对应字段的同时,在addrs数组中使用$filter进行内部过滤,返回最终结果集

db.getCollection('user').aggregate(
  [
    { 
      $match : { "uid": "1000001" } 
    },
    {
      $project: {
        "uid": 1,
        "name": 1,
        "addrs": {
          $filter: {
            input: "$addrs",
            as: "item",
            cond: { $eq : ["$$item.is_query","1"] }
          }
        }
      }
    }
  ]
)

Result:

{
  "_id" : ObjectId("5bbcc0c9a74db9804e78a157"),
  "uid" : "1000001",
  "name" : "zhangsan",
  "addrs" : [ 
    {
      "is_query" : "1",
      "city" : "北京"
    }, 
    {
      "is_query" : "1",
      "city" : "深圳"
    }
  ]
}

相对于$group分组聚合返回结果集的方式,在当前查询要求下$filter显得更加优雅一些,也比较直接。当然如果包含统计操作,比如要求返回is_query等于1的数量,这时候$group就非常合适了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • 分布式文档存储数据库之MongoDB访问控制的操作方法
  • 分布式文档存储数据库之MongoDB备份与恢复的实践详解
  • 分布式文档存储数据库之MongoDB分片集群的问题
  • SpringDataMongoDB多文档事务的实现
  • MongoDB中文档的更新操作示例详解
  • MongoDB数据库文档操作方法(必看篇)
  • mongodb 数据类型(null/字符串/数字/日期/内嵌文档/数组等)
  • PHP库 查询Mongodb中的文档ID的方法
  • MongoDB如何更新多级文档的数据

标签:玉林 鸡西 自贡 无锡 辽阳 兴安盟 厦门 泰安

巨人网络通讯声明:本文标题《mongodb如何对文档内数组进行过滤的方法步骤》,本文关键词  mongodb,如何,对,文档,内,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《mongodb如何对文档内数组进行过滤的方法步骤》相关的同类信息!
  • 本页收集关于mongodb如何对文档内数组进行过滤的方法步骤的相关信息资讯供网民参考!
  • 推荐文章