1

ここではMongoDB Map Reduceを使用しています...しかし、ここで何が問題になっているのかに関するドキュメントは見つかりません。とにかく-ここにサンプルドキュメントがあります:

配列 ( [_id] => MongoId オブジェクト ( [$id] => 5076e95791fa5e4c69002ec3 )

[dataProviders] => Array
    (
        [0] => Array
            (
                [key] => facebook
                [data] => Array
                    (
                        [id] => 100001583260053
                        [name] => MyName
                        [link] => http://www.facebook.com/Mynameagain
                        [username] => MyName
                        [birthday] => 02/19/1959
                        [hometown] => Array
                            (
                                [id] => 104022969633581
                                [name] => MyName
                            )

                        [location] => Array
                            (
                                [id] => 104022969633581
                                [name] => MyHome
                            )

                        [bio] => MyBio
                        [work] => Array
                            (
                                [0] => Array
                                    (
                                        [employer] => Array
                                            (
                                                [id] => 119738361373063
                                                [name] => .....
                                            )

                                        [start_date] => 0000-00
                                        [end_date] => 0000-00
                                    )

                            )

                        [education] => Array
                            (
                                [0] => Array
                                    (
                                        [school] => Array
                                            (
                                                [id] => 108891959147272
                                                [name] => ....
                                            )

                                        [type] => High School
                                    )

                                [1] => Array
                                    (
                                        [school] => Array
                                            (
                                                [id] => 133940149955590
                                                [name] => .....
                                            )

                                        [type] => College
                                    )

                            )

                        [gender] => female
                        [email] => MyEmail@myemail.com
                        [timezone] => 2
                        [locale] => US
                        [languages] => Array
                            (
                                [0] => Array
                                    (
                                        [id] => 106412222728952
                                        [name] => MyName
                                    )

                            )

                        [verified] => 1
                        [updated_time] => 2012-08-10T17:33:16+0000
                        [avatarUrl] => https://graph.facebook.com/1000/picture
                        [avatarUrlOriginal] => https://graph.facebook.com/1000/picture?type=large
                        [avatarUrlLarge] => https://graph.facebook.com/1000/picture
                    )

            )

    )

私の問題は、このグループから Facebook ユーザーのみをプルする際に、基本的な MapReduce を実行しようとしていることです。基本的に私は非常に簡単なカウントをしたいです。私が見ることができることから、これは機能する必要がありますが、エラーメッセージが表示されます:

error_reporting(E_ALL);
ini_set('display_errors', '1');
include "phpmapreduce/lib/MongoMapReduce.php";
include "phpmapreduce/lib/MongoMapReduceResponse.php";
include "phpmapreduce/lib/XMongoCollection.php";

$collection_name = "users";

$map = "function(){emit({source: this.dataProviders.0.key}, {count: 1}); }}";

$reduce = "function(key, values){
            var sum= {count: []};
            for(var i in values)  
                sum += values[i];
            return sum;
            }";
$query = array('dataProviders.0.key' => 'facebook');

echo "Here's our map Function! <br/>";
$mapFunc = new MongoCode($map); 
echo "<pre>";
print_r($mapFunc);
$reduceFunc = new MongoCode($reduce);
print_r($reduceFunc);
$command= array(
       "mapreduce"=>'texasHoldem.users',
    "map"=>$mapFunc,
    "reduce"=>$reduceFunc,
        "query" =>$query,
         "out" => array(
             "inline" => 1)
);
try {
    $mongo = new Mongo('mongodb://1.2.3.4.5.6.7./mydb', array("replicaSet" => true));
}
catch(MongoConnectionException $e) {
    $msg = "Error Connecting to MongoDB" . "<br/>";
    die($msg);
}
echo "Connected" . "<br/>";
$db = $mongo->selectDb('yallapop');

echo "got mydb!" . "<br/>";

$db->setSlaveOkay(); // This line is needed to be able to read from slave
$collection= $db->selectCollection('texasHoldem.users'); // Users collection
echo "Got the Collection" . "<br/>";
echo "setting timeout" . "<br/>";
//$cursor = $collection->find()->timeout(30000);
MongoCursor::$timeout = -1;
echo "<pre>";
echo "let's do this! Running command" . "<br/>";

$statsInfo = $db->command($command);
print_r($statsInfo);

SO this works well up to this point: 
Connected
got myDB!
data established
setting timeout
Got the Collection
setting timeout

let's do this! Running command
Array
(
    [errmsg] => exception: couldn't compile code for: _map
    [code] => 13598
    [ok] => 0
)

この特定のエラーについてはどこにも見つかりません。_map 関数はコンパイルできません。これは前に見たことがありません。他に経験者はいますか?MongoDB と PHP 5.3 を使用しています。ありがとう!

4

1 に答える 1

2

コードにいくつかの構文エラーがあるようです。それがコンパイルできない理由です。

map関数には閉じ中括弧が多すぎます。また、発行キーもドキュメントであってはなりません。

$map = "function() {
    emit( this.dataProviders.0.key, {count: 1});
}";

関数ではreduce、合計を合計したいだけであれば、 に配列は必要ありませんsum。ただ行う:

$reduce = "function(key, values) {
    var sum = {count: 0};
    for (var i in values) {
        sum.count += values[i].count;
    }
    return sum;
}";

それがあなたのために働くかどうか試してください。

于 2012-10-24T04:17:17.690 に答える