2

次の形式のmongodbコレクションがあります:

{
        "_id" : ObjectId("5141916511e5b498fd2031c4"),
        "itemid" : 1,
        "recommendations" : [
                {
                        "itemid" : 216,
                        "rating" : 0.875297364790784
                },
                {
                        "itemid" : 246,
                        "rating" : 0.8793363655122852
                }
        ]
}
{
        "_id" : ObjectId("5141916511e5b498fd2031c5"),
        "itemid" : 2,
        "recommendations" : [
                {
                        "itemid" : 60,
                        "rating" : 0.9405825249353504
                },
                {
                        "itemid" : 76,
                        "rating" : 0.8822827294664317
                }
        ]
}

特定の itemid の推奨事項を取得し、それを繰り返し処理して、推奨されるすべての itemid と評価を出力したいと考えています。これには php を使用しています。

返されたカーソルを反復しようとすると、「致命的なエラー: 非オブジェクトでのメンバー関数 hasNext() の呼び出し」エラーがスローされます。クエリによって返された結果セットはカーソル型ではないようです。

以下は私が使用しているコードです:

<?php
$mongodb = new Mongo("10.128.170.49:27017");
$database = $mongodb->ProductData;
$collection = $database->Recommendation1;

$cursor1 = $collection->findOne(array("itemid" => 1),array('recommendations'));

var_dump($cursor1);

echo "<hr/><p>iterating over a cursor</p>";
while ($cursor1->hasNext()): $document = $cursor1->getNext(); 
                        $itemid= $document['itemid'];
                        $probable_rating= $document['rating'];                      
                         echo ($itemid)."<br/>";
                         echo ($probable_rating)."<br/>";
                         echo "<hr/>";
endwhile;
?>

この問題の解決を手伝ってください。

4

1 に答える 1

4

に変更する必要がありfindOne()ますfind()

  • findOne()最初に見つかった結果を返します
  • find()カーソルを返します
于 2013-03-21T09:23:59.540 に答える