2013-11-22 103 views
0

我有一个JavaScript文件作为蒙戈 - 如何访问由组返回的数据减少

var x = new Mongo('127.0.0.1:27017'); 
var db = x.getDB('user'); 
var r = db.runCommand({"group" : { 
           "ns" : "track_user", "key" : {userId : 1}, "initial" : { 
         count:0 }, cond: { 
             uri: { 
              $regex: 'sm' 
             } }, "$reduce" : function(doc, prev) { 
              } } }  }}); 


while(r.hasNext()){ 
    rs = r.next(); 
}  

我不能够通过组返回减少的结果运行。 输出组的减少通过shell中运行是一样的东西

{ 
    "retval" : [ 
     { 
      "userId" : 0, 
      "created" : "2013-08-08 11:32:15", 
      "uri" : "abc.com", 
      "uri_set" : [ 
       "xyz.com" 
      ] 
     },... 

    ], 
    "count" : 14, 
    "keys" : 6, 
    "ok" : 1 
} 

hasNext是给误差

Sat Nov 23 00:53:40.351 JavaScript execution failed: TypeError: Object [object Object] has no method 'hasNext' at /var/www/admin/app/controllers/newjavascript1.js:L62 

请尽快帮忙。

回答

0

问题是db.runCommand()没有返回游标,所以没有任何游标方法可以处理它。您将返回一个嵌入了结果的文档,因此您将不得不以不同的方式处理数据。

您应该能够要么使用mapeach,这取决于你想做什么:

var mySet = r.retval; 

mySet.forEach(function(doc) { 
    console.log(doc); 
}); 

或者任何你需要做的。