MongoDB中对数据统计有哪些方式和应用
Admin 2022-05-27 群英技术资讯 692 次浏览
用mongodb中的aggregate统计数据:
应用一:统计name的数量和总数;
db.collection.aggregate([ {$group:{_id:"$name",count:{$sum:1},total:{$sum:"$num"}} ]);
应用二:统计status=1的name的数量;
db.collection.aggregate([ {$match:{status:1}}, {$group:{_id:"$name",count:{$sum:1}}} ]);
应用三:统计name的数量,并且数量为小于2的;
db.collection.aggregate([ {$group:{_id:"$name",count:{$sum:1}}, {$match:{count:{$lt:2}}} ]);
应用四:统计stauts=1的name的数量,并且数量为1的;
db.collection.aggregate([ {$match:{status:1}}, {$group:{_id:"$name",count:{$sum:1}}}, {$match:{count:1}} ]);
多列group,根据name和status进行多列
db.collection.aggregate([ {$group:{_id:{name:"$name",st:"$status"},count:{$sum:1}}} ]); $project该操作符很简单, db.collection.aggregate([ {$project:{name:1,status:1}} ]);
结果是,只有_id,name,status三个字段的表数据,相当于sql表达式 select _id,name,status from collection
操作符介绍:
$project:包含、排除、重命名和显示字段
$match:查询,需要同find()一样的参数
$limit:限制结果数量
$skip:忽略结果的数量
$sort:按照给定的字段排序结果
$group:按照给定表达式组合结果
$unwind:分割嵌入数组到自己顶层文件
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
MongoDB分片是什么?很多刚接触MongoDB数据库的朋友可能对于MongoDB分片不是很清楚,下面小编就给大家介绍一下MongoDB分片的相关内容,感兴趣的朋友可以了解一下。
MongoDB 关系 MongoDB 的关系表示多个文档之间在逻辑上的相互联系。 文档间可以通过嵌入和引用来建立联系。 MongoDB 中的关系可以是: 1:1 (1对1) 1: N (1对多) N: 1 (多对1) N: N (多对多) 接下来我们来考虑下用户与用户地址的关系。 一个用户可以有多个地址,所以是一对多的关系。 以下是 user 文档的简单结构: { '_id':ObjectId(�..
mongodb插入时间错误的原因:存储在mongodb中的时间标准UTC +0:00,而中国的时区是+8:00;解决方法:在插入时间时用DateTime.SpecifyKind命令对时间进行处理。
MongoDB 数据库引用 在上一章节MongoDB关系中我们提到了MongoDB的引用来规范数据结构文档。 MongoDB 引用有两种: 手动引用(Manual References)DBRefs DBRefs vs 手动引用 考虑这样的一个场景,我们在不同的集合中 (address_home, address_office, address_mailing, 等)存储不同的地址(住址,办公室地址,邮件地址等)。 这样,我们在调..
mongodb查看索引的方法:1、使用getIndexes()方法查看所有索引。2、使用totalIndexSize()查看集合索引的总大小。3、使用db.system.indexes.find()方法查看所有索引信息。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008