Php/docs/mongocode.construct

From Get docs

MongoCode::__construct

(PECL mongo >= 0.8.3)

MongoCode::__constructCreates a new code object


This extension that defines this method

is deprecated. Instead, the MongoDB extension should be used. Alternatives to this method include:

Description

public MongoCode::__construct ( string $code [, array $scope = array() ] )

Parameters

code
A string of code.
scope
The scope to use for the code.


Return Values

Returns a new code object.


Examples

Example #1 MongoCode::__construct() example

<?php$code = new MongoCode('function() { '.    'for(i=0;i<10;i++) {'.        'db.foo.update({z : i}, {z : x});'.    '}'.    'return x-1;'. '}', array("x" => 4));var_dump($code);?>

The above example will output something similar to:


object(MongoCode)#1 (2) {
  ["scope"]=>
  array(1) {
    ["x"]=>
    int(4)
  }
  ["code"]=>
  string(80) "function() { for(i=0;i<10;i++) { db.foo.update({z : i}, {z : x}); } return x-1; }"
}

Example #2 Using MongoCode with $where

This example queries a collection for elements where the 'x' fields is less than $y. Notice that PHP objects can be passed into the JavaScript scope and that the JavaScript function returns a boolean.


<?php$cursor = $collection->find(array('$where' => new MongoCode('function() { return this.x < y; }', array('y'=>$y))));?>