MongoDB组查询在终端中工作,在nodejs文件中抛出错误

时间:2012-09-11 00:20:11

标签: node.js mongodb collections grouping

我有一个查询在查询我的mongodb集合的终端中工作正常,但是在我想要对数据进行分组的函数内部,我收到以下错误:

// QUERY WORKS:
/*
> db.twitterhashtags.group({ key: {"text":true}, initial: {sum:0}, reduce: function(doc, prev) {prev.sum +=1}});
 [
{
    "text" : "spnyc",
    "sum" : 1
},
{
*/
//RUNNING QUERY CAUSES THIS ERROR:
// TypeError: undefined is not a function
// at Collection.group.scope (/Users/propstm/Projects/nodeproject/node_modules/mongoskin/node_modules/mongodb/lib/mongodb/collection.js:1341:16)
//at g (events.js:185:14)

这是引发上述错误的代码行。

db.collection("twitterhashtags").group({ key: {"text":true}, initial: {sum:0}, reduce: function(doc, prev) {prev.sum +=1}});

1 个答案:

答案 0 :(得分:2)

驱动程序没有100%遵循控制台约定。文档中有使用组的示例。

http://mongodb.github.com/node-mongodb-native/api-generated/collection.html#group

但是,如果它是一个新的应用程序并且您使用的是2.2,则除非必须使用聚合框架,否则不应使用组。

http://docs.mongodb.org/manual/aggregation/