按日期范围分组 mongodb

Posted

技术标签:

【中文标题】按日期范围分组 mongodb【英文标题】:Group by dates range mongodb 【发布时间】:2015-01-03 22:54:25 【问题描述】:

我在数据库中有这个集合

[name:1,startDate:1/1/13,endDate:2/2/13,number:10,
name:1,startDate:2/2/13,endDate:5/2/13,number:15,
name:2,startDate:2/1/13,endDate:5/2/13,number:25,
name:1,startDate:5/2/13,number:17,
name:2,startDate:5/2/13,number:30]

我想得到一个开始日期的列表,其中包含这个开始日期范围内的数字的平均值,例如,这个集合的结果是:

date:1/1/13,avg:10,
date:2/1/13,avg:17.5,
date:2/2/13,avg:20,
date:5/2/13,avg:23.5

我尝试了一些 map-reduce 和 group,但没有一个可以正确按开始日期分组, 请帮忙。

【问题讨论】:

你能解释一下你是如何计算这个平均值的吗? 第一个结果是 10,因为在 2013 年 1 月 1 日没有涉及其他日期 第二个是 17.5,因为集合中的第一项和第三项在 2/1/13 日期 这样解释好吗? 解释很好,但您应该编辑您的问题,因为在第一个文档中 2/1/13 日期不存在? 【参考方案1】:

您可以使用聚合管道来做到这一点:

db.collectionName.aggregate([$group:_id:'$startDate',avg:$avg:'$number'])

这将按 startDate 对集合进行分组,并且聚合是数字的平均值。

如果您严格希望 _id 字段标记为 startDate,则在管道中使用 $project 操作:

db.collectionName.aggregate([$group:_id:'$startDate', avg:$avg:'$number',$project:'startDate':'$_id', 'avg':'$avg',_id:0])

这会得到想要的结果。

【讨论】:

不,它没有。也许您应该阅读给出的 cmets。 “2/1/13”不能按要求产生 17.5,因为那不是“start_date” 对不起,不是我的意思,这没有得到答案......我正在寻找一个日期范围内的平均数。【参考方案2】:

由于没有更好的方法,我只是从服务器端完成,

首先获取所有 startDate ,然后执行迭代,查找日期范围内的每个文档并对其数量进行平均...

没有放弃我期望的解决方法,但它可以正常工作。

【讨论】:

以上是关于按日期范围分组 mongodb的主要内容,如果未能解决你的问题,请参考以下文章

按名称分组的连续日期范围内的最小和最大日期

按日期范围分组 mongodb

Oracle - 按类别分组,日期范围[重复]

在mysql和php中按日期范围分组

SQLite 按选定日期范围内的所有日期分组,即使数据不存在

选择日期范围,根据关闭条件计算范围内的多条记录,按班次分组