在实现文档聚合时,需统计文章评论者的平均年龄,使用aggregate方法中的管道操作符
g
r
o
u
p
,
表
达
式
为
group,表达式为
group,表达式为avg,结果数据为空。
检查后发现,在文档数据录入时,将数字作为字符串进行了存储。
一、聚合过程如下。
1. 添加集合和文档
db.comment.insertMany([
{ "_id" : 1, "articleID" : "100001", "age" : "20" },
{ "_id" : 2, "articleID" : "100001", "age" : "30" },
{ "_id" : 3, "articleID" : "100001", "age" : "40" },
{ "_id" : 4, "articleID" : "100002", "age" : "30" },
{ "_id" : 5, "articleID" : "100002", "age" : "30" },
{ "_id" : 6, "articleID" : "100002", "age" : "60" }
])
2. 查看文档内容
db.comment.find().pretty()
结果输出如下。
3. 聚合,分组统计每篇文章评论者的平均年龄
从结果看,aggregate根据articleID分组成两个类别,但平均年龄统计为null
二、解决方法
4. 使用typeof查看文档中列的数据类型。
typeof db.comment.findOne().age
从结果可以看到当前age的数据类型为string,因此在进行分组统计时,结果为null
5. 将age列的字符串类型更改为整数类型
可以使用find()方法的forEach方法进行迭代修改
db.comment.find().forEach(
function (x) {
x.age = parseInt(x.age);
db.comment.save(x);
}
)
执行完上述代码。
6. 重新查看age的数据类型![在这里插入图片描述](https://img-blog.csdnimg.cn/b591eea8a58c48d7a5d87d31057c6d7f.png)
此时age的数据类型为number.
7. 重新统计
此时统计出了两个分类的平均年龄。
从这个错误可知,Mongodb数据库录入数据时,需要注意数据本身的数据类型,以免出错。