mongodb如何对文档内数组进行过滤的方法步骤
2019-01-23 12:21
891 查看
本文介绍了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就非常合适了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 如何用Perl对字符串或者数字数组进行排序。 hash 按value/按keys 排序(多种方法)。
- JavaScript中数组如何过滤掉相同元素的5种方法
- MongoDB下根据数组大小进行查询的方法
- 如何对 MongoDB 进行性能优化(五个简单步骤)
- 如何对 MongoDB 进行性能优化(五个简单步骤)
- js:数组重排序问题:如何使用sort()方法按数值的大小进行升序或降序排列
- MongoDB下根据数组大小进行查询的方法
- MongoDB如何对数组中的元素进行查询详解
- 如何使blackberry与outlook进行数据同步方法步骤
- mongodb对数组中的所有元素进行一次性修改方法(限3.6版本)
- 数组如何作为方法的参数
- 如何用js实现,在一个页面有个输入文档框,然后点击查询按扭后,调用IE的查询功能在当前页面进行查询
- 如何使用RMS对文档权限进行限制
- 8.6 对接受数组方法的成员方法进行反射
- C#换行符如何过滤的方法
- Visual C#2005——如何使用ToArray方法返回一个强类型数组
- powerDesigner中如何name与code进行同步的解决方法
- .NET :如何对数组进行排序
- ARM开发板如何挂载NFS开发环境的方法步骤(
- ubuntu 10.04下进行安装wireshark的安装步骤和方法