从 PHP 调用存储在 MongoDB 中的 JavaScript 函数

Posted

技术标签:

【中文标题】从 PHP 调用存储在 MongoDB 中的 JavaScript 函数【英文标题】:Calling stored JavaScript function in MongoDB from PHP 【发布时间】:2010-10-14 22:27:49 【问题描述】:

我有这个函数存储在 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 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"))
);

错误

Array
(
    [errno] => -3
    [errmsg] => invoke failed: JS Error: ReferenceError: o is not defined nofile_a:0
    [ok] => 0
)

【问题讨论】:

$db->e​​xecute( new MongoCode('AutoID(o)', array( 'o' => array('name' => 'test') ) ) ); 很高兴看到你已经解决了。随时发布您的解决方案作为答案并接受它。这样问题就不会看起来像没有答案:) 【参考方案1】:
$db->execute(
    new MongoCode('SomeFunc(o)', array(
        'o' => array('name' => 'test') 
    ))
);

【讨论】:

以上是关于从 PHP 调用存储在 MongoDB 中的 JavaScript 函数的主要内容,如果未能解决你的问题,请参考以下文章

资源 | PHP之 MongoDB 从配置到编程视频

使用 SQL Server 2012 中的 MSSQL_Query 的 PHP 调用存储过程返回无效值

从 PHP 中的存储过程获取输出

如何从存储在 mongodb 中的对象中获取日期?

如何使用 PHP 驱动程序在 MongoDB 中创建存储函数

从 MS SQL 中的 PHP PDO 存储过程中返回 Select *