Mongodb中文档聚合时数值数据为空

在实现文档聚合时,需统计文章评论者的平均年龄,使用aggregate方法中的管道操作符 g r o u p , 表 达 式 为 group,表达式为 groupavg,结果数据为空。
检查后发现,在文档数据录入时,将数字作为字符串进行了存储。

一、聚合过程如下。

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的数据类型在这里插入图片描述

此时age的数据类型为number.

7. 重新统计

在这里插入图片描述
此时统计出了两个分类的平均年龄。
从这个错误可知,Mongodb数据库录入数据时,需要注意数据本身的数据类型,以免出错。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值