博客
关于我
Mongodb中的聚合函数使用:按月统计数量
阅读量:798 次
发布时间:2023-02-09

本文共 647 字,大约阅读时间需要 2 分钟。

案例:mongodb中有统计表(stat_list)表,存有每天的统计数据,现在需要按月计算,则需要用到mongo的聚合函数aggregate。

"_id" : ObjectId("5d00d3b66939c1efb80ba325"), "date" : "2019-06-12", "daily_count" : "164.34万",

解决方案:

1、将daily_count去掉万字,然后再转成整型相加;(PS:吐槽下,不知道为什么最原始的数据源要存成这样,最好还是不要带单位存储)
2、将date中的月份提取;
直接用substr即可。

第一步中将万字去掉并转成整型,直接遍历更新下数据即可。
原数据:daily_count" : "164.34万" 更新后的数据:daily_count" : 164.34
第一种正则表达式匹配
db.getCollection('stat_list_copy').find().forEach(    function(item){        friendsCount = item.daily_count        friendsCount = (friendsCount.match(/.*?(?=万)/))        newFriendsCount = parseFloat(friendsCount[0])        db.getCollection('stat_list_copy').update({'_id':item.

转载地址:http://djffk.baihongyu.com/

你可能感兴趣的文章
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>
【Java基础】什么是面向对象?
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>