Наша группа в Telegram для обмена идеями, проектами, мыслями, людьми в сфере ИТ г.Ростова-на-Дону: @it_rostov

MongoDB::execute

(PECL mongo >=0.9.3)

MongoDB::execute — Runs JavaScript code on the database server.


Описание

public array MongoDB::execute ( mixed $code [, array $args = array() ] )

The Mongo database server runs a JavaScript engine. This method allows you to run arbitary JavaScript on the database. This can be useful if you want touch a number of collections lightly, or process some results on the database side to reduce the amount that has to be sent to the client.

Running JavaScript in the database takes a write lock, meaning it blocks other operations. Make sure you consider this before running a long script.

This is a wrapper for a database command. This method is basically:

public function execute($code, $args) {
    return $this->command(array('$eval' => $code, args => $args));
}

MongoDB implies a return statement if you have a single statement on a single line. This can cause some unintuitive behavior. For example, this returns "foo":

$db->execute('"foo";');

However, these return NULL:

$db->execute('"bar"; "foo";'); // more than one statement
$db->execute('db.foo.count(
);'); // more than one line

To avoid surprising behavior, it is best not to depend on MongoDB to decide what to return, but to explicitly state a return value. In the examples above, we can change them to:

$db->execute('"bar"; return "foo";');
$db->execute('return db.foo.count(
);');

Now the first statement will return "foo" and the second statement will return a count of the "foo" collection.


Список параметров

code -

MongoCode or string to execute.

args -

Arguments to be passed to code.


Возвращаемые значения

Returns the result of the evaluation.


Примеры

Пример #1 Simple MongoDB::execute() example
$response = $db->execute("function() { return 'Hello, world!'; }");
echo $response['retval'];

Результатом выполнения данного примера будет что-то подобное:


Hello, world!
Пример #2 Parameter MongoDB::execute() example

The optional array of parameters will be passed to the JavaScript function.


$response = $db->execute("function(greeting, name) { return greeting+', '+name+'!'; }", array("Good bye", "Joe"));
echo $response['retval'];

Результатом выполнения данного примера будет что-то подобное:


Good bye, Joe!
Пример #3 Scope example

If a MongoCode object is used instead of a string for the first parameter, a scope can be passed in which the JavaScript will be executed.


$func = 
    "function(greeting, name) { ".
        "return greeting+', '+name+', says '+greeter;".
    "}";
$scope = array("greeter" => "Fred");
$code = new MongoCode($func, $scope);
$response = $db->execute($code, array("Goodbye", "Joe"));
echo $response['retval'];

Результатом выполнения данного примера будет что-то подобное:


Goodbye, Joe, says Fred

Описание класса mongodb, примеры использования класса mongodb.



Смотрите также:
Описание на ru2.php.net
Описание на php.ru