当我运行下面存储的 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" }
为什么?请帮我?
find() 函数返回一个游标,而 JavaScript 无法返回该游标。
这建议的解决方法 http://groups.google.com/group/mongodb-user/browse_thread/thread/0d205f9aefd12994就是使用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
}
]
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)