从PHP调用MongoDB中存储的JavaScript函数
我将此函数存储在db.system.js中从PHP调用MongoDB中存储的JavaScript函数,php,mongodb,java-stored-procedures,mongodb-php,Php,Mongodb,Java Stored Procedures,Mongodb Php,我将此函数存储在db.system.js中 function SomeFunc(o) { x = db.Collection; while( 1 ) { var c = x.find({},{_id:1}).sort({_id:-1}).limit(1); var i = c.hasNext() ? c.next()._id + 1 : 1; o._id = i; x.insert(o); var e
function SomeFunc(o) {
x = db.Collection;
while( 1 ) {
var c = x.find({},{_id:1}).sort({_id:-1}).limit(1);
var i = c.hasNext() ? c.next()._id + 1 : 1;
o._id = i;
x.insert(o);
var err = db.getLastErrorObj();
if( err && err.code ) {
if( err.code == 11000 /* dup key */ )
continue;
else
print("unexpected error inserting data: " + tojson(err));
}
break;
}
}
在PHP中
print_r(
$db->execute("SumeFunc(o)", array("name" => "test"))
);
错误
$db->execute(新的MongoCode('AutoID(o'),array('o'=>array('name'=>'test')));很高兴看到你解决了这个问题。请随意发布您的解决方案作为答案并接受它。这样问题就不会看起来没有答案:)
Array
(
[errno] => -3
[errmsg] => invoke failed: JS Error: ReferenceError: o is not defined nofile_a:0
[ok] => 0
)
$db->execute(
new MongoCode('SomeFunc(o)', array(
'o' => array('name' => 'test')
))
);