2011-10-09 48 views
5

当我运行下面的存储JavaScript函数,我得到的错误:的MongoDB:错误执行存储JavaScript函数

> db.system.js.save({_id:"last_n_users", value: function(n){return db.users.find().sort({created_at:-1}).limit(n)}}) 
> db.eval("last_n_users(10)") 

这里是错误:

{ "value" : "DBQuery: store.users -> undefined" } 

为什么?请帮帮我?

回答

10

find()函数返回一个无法从JavaScript返回的游标。 suggested workaround是使用toArray()来获取数组的返回值。

例...之前:

> use admin 
switched to db admin 
> db.system.js.save({ _id : "foo", value: function(n){return db.system.indexes.find().limit(n)} })   
> db.eval("foo(3)")                    
{ "value" : "DBQuery: admin.system.indexes -> undefined" } 

就像你描述。
和之后:

> db.system.js.save({ _id : "foo", value: function(n){return db.system.indexes.find().limit(n).toArray()} }) 
> db.eval("foo(3)")                       
[ 
     { 
       "name" : "_id_", 
       "ns" : "admin.system.users", 
       "key" : { 
         "_id" : 1 
       } 
     }, 
     { 
       "name" : "user_1", 
       "ns" : "admin.system.users", 
       "key" : { 
         "user" : 1 
       }, 
       "unique" : false 
     }, 
     { 
       "name" : "_id_", 
       "ns" : "admin.whee", 
       "key" : { 
         "_id" : 1 
       }, 
       "v" : 0 
     } 
] 
+0

这太棒了。非常感谢你。 – Zeck

+0

不客气!很高兴我能帮上忙。 :) – dampier