时间:2021-07-01 10:21:17 帮助过:29人阅读
--求学生的总人数和平均年龄 db.stu.aggregate( {$group:{_id:null, count:{$sum:1}, avg_scroe:{$avg:‘$age‘}}} )
-- 统计不同性别的学生姓名 db.stu.aggregate( {$group:{_id:‘$gender‘, name:{$push:‘$name‘}}} )
-- 查询年龄大于20的学生 db.stu.aggregate( {$match:{age:{$gt:20}}} ) --查询年龄大于20的男生与女生人数 db.stu.aggregate( {$match:{age:{$gt:20}}}, {$group:{_id:‘$gender‘,counter:{$sum:1}}} )
--查询 只显示学生的姓名,年龄 db.stu.aggregate({$project:{_id:0, name:1, age:1}}) --查询男生,女生人数, 只输出性别和人数 db.stu.aggregate( {$group:{_id:‘$gender‘, count:{$sum:1}}}, {$project:{_id:0,gender:‘$_id‘, count:1}} )
--查询学生信息, 按年龄升序排列 db.stu.aggregate( {$sort:{age:1}} ) -- 查询男生和女生人数, 按人数降序排 db.stu.aggregate( {$group:{_id:‘$gender‘, count:{$sum:1}}}, {$project:{_id:0,gender:‘$_id‘, count:1}}, {$sort:{count:-1}} )
--查询从第3条开始的学生信息 --$limit: 限制聚合管道返回的文档数量 db.stu.aggregate({$skip:2}) ? --查询2条学生信息 db.stu.aggregate({$limit:2}) ? --统计男生,女生人数, 按人数升序, 取出第二条数据 db.stu.aggregate( {$group:{_id:‘$gender‘, count:{$sum:1}}}, {$sort:{count:1}}, {$skip:1}, {$limit:1} )
db.t3.insert({_id:1,item:‘t-shirt‘,size:[‘S‘,‘M‘,‘L‘]}) --$unwind 将集合拆分 db.t3.aggregate({$unwind:‘$size‘})结果:
{ "_id" : 1, "item" : "t-shirt", "size" : "S" } { "_id" : 1, "item" : "t-shirt", "size" : "M" } { "_id" : 1, "item" : "t-shirt", "size" : "L" }
问题: 在使用$unwind的时候, 默认会丢弃属性值为空的文档. 如果希望保留,需要把设置 preserveNullAndEmptyArrays 为true db.集合名.aggregate([ {$unwind:{ path:‘$字段名称‘ preserveNullAndEmptyArrays:true(保留)/false(丢弃) } ])
MongoDB-管道与聚合(3)
标签:排序 gre item 集合 类型 年龄 组类型 设置 font