关于流星收集的"分组依据"查询

shi*_*ana 5 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"}
Run Code Online (Sandbox Code Playgroud)

在流星中:

Customer = new Meteor.Collection("CUSTOMER");
Run Code Online (Sandbox Code Playgroud)

我试图按照日期(星期一,星期二,星期三,......)将它们与流星集合以及数据总数进行分组.它应该是这样的:

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

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

{"Date": "Sat Feb 01 2014", "Total" 2}
Run Code Online (Sandbox Code Playgroud)

在mongoDB中,我只是使用http://docs.mongodb.org/manual/reference/method/db.collection.group/,但显然,它在流星中是不可能的,因为它不支持findAndModify,upsert ,聚合函数和map/reduce.

我有什么办法可以解决这个问题吗?

谢谢

Dav*_*don 10

您需要手动对它们进行分组.有很多方法可以做到这一点,但这是一个(难以理解的难以阅读)的例子:

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

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

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


Nei*_*unn 7

可以使用meteor 来管理这些功能,或者找到描述客户端处理的链接,但是从服务器端来看它是不同的.

在大多数情况下,您应该使用聚合而不是mapReduce或组函数.整个管道是用C++实现的,而不是传递给JavaScript引擎.在所有情况下,聚合管道中的等效函数将更快.

> db.dates.aggregate([
    {$group: { _id: {$dayOfWeek: "$CreatedDate"}, Total: {$sum: 1} }},
    {$project: { _id: 0, day: "$_id", Total: 1 } },
    {$sort: { day: 1 }}
  ])


  {
    "result" : [
            {
                    "Total" : 1,
                    "day" : 4
            },
            {
                    "Total" : 1,
                    "day" : 6
            },
            {
                    "Total" : 2,
                    "day" : 7
            }
    ],
    "ok" : 1
  }
Run Code Online (Sandbox Code Playgroud)

关于流星支持

服务器端,meteor使用node-mongodb-native驱动程序进行所有处理.它由MongoDB维护并维护所有功能.

客户端是一个名为"mini-mongo"的库.这实际上不是一个驱动程序,而是一个实际上使用套接字连接将细节传递到服务器的小层.它使你的客户端javascript"看起来"与服务器端代码相同,但你实际上并没有直接与mongo交谈.

使用"发布"的服务器端功能client来调用server侧面的自定义代码没有任何问题.如上所述,它只是您可以在其他nodejs应用程序中使用的标准驱动程序.