• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    mongodb如何对文档内数组进行过滤的方法步骤

    本文介绍了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增量备份脚本的实现和原理详解
    下一篇:mongo数据集合属性中存在点号(.)的解决方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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