mongodb - "group by"对 meteor 收集的查询

标签 mongodb meteor aggregation-framework

我的数据mongoDB:

>db.CUSTOMER.find()

{"Name": "A", "CreatedDate": "Wed Jan 29 2014"}

{"Name": "B", "CreatedDate": "Fri Jan 31 2014"}

{"Name": "C", "CreatedDate": "Sat Feb 01 2014"}

{"Name": "D", "CreatedDate": "Sat Feb 01 2014"}

在 meteor 中:

Customer = new Meteor.Collection("CUSTOMER");

我正在尝试在 meteor 收集中按日期(周一、周二、周三...)以及数据总数对它们进行分组。应该是这样的:

{"Date": "Wed Jan 29 2014", "Total" 1}

{"Date": "Fri Jan 31 2014", "Total" 1}

{"Date": "Sat Feb 01 2014", "Total" 2}

在 mongoDB 中,我会选择 http://docs.mongodb.org/manual/reference/method/db.collection.group/ ,但显然在meteor中是不可能的,因为它不支持findAndModify、upsert、聚合函数和map/reduce。

有没有我可以做的变通方法的例子来使它起作用?

谢谢

最佳答案

您需要手动对它们进行分组。有很多方法可以做到这一点,但这里有一个(诚然难以阅读)示例:

var customers = Customer.find().fetch();

var groupedDates = _.groupBy(_.pluck(customers, 'CreatedDate'));

_.each(_.values(groupedDates), function(dates) {
  console.log({Date: dates[0], Total: dates.length});
});

关于mongodb - "group by"对 meteor 收集的查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21692965/

相关文章:

mongodb - 当前字段的聚合条件计数

java - 使用现有的mongodb数据库快速开发java web-app

javascript - 如果本地字段存在于外部字段中则聚合

javascript - 语义 Ui 下拉功能摆脱模板功能

database - MongoDB 从多个文档中提取子文档数组值

javascript - MongoDB mapReduce 方法意外结果

node.js - Mongoose 查找或操作符失败

node.js - 想在mongodb node.JS中通过_id获取引用集合的对象

javascript - $meteor.collection 不返回集合

Mongodb 对内部数组进行排序