Doctrine MongoDB Bundle: Cursor toArray() 错误,当 “_id” 是一个数组


Doctrine MongoDB Bundle: Cursor toArray() Error When "_id" is an Array

由MapReduce产生,我有一个具有以下结构的MongoDb集合:

{ "_id" : { "id" : NumberLong(1), "date" : "04-26-2012" }, "value" : { "count" : 100 } }

在我的控制器中,我正在执行以下操作以返回一个数组以显示结果:

$mongoDb         = $mongo->selectDatabase($dbname);        
$mongoCollection = $mongoDb->selectCollection($collname);
$qb              = $mongoCollection->createQueryBuilder(); 
$qb              = $qb->find();        
$resultCursor    = $qb->getQuery()->execute();
                                  ->limit(10);
$resultArray     = $resultCursor  ->toArray();

但是,我得到一个例外:"注意:vendor/doctrine-mongodb/lib/Doctrine/MongoDB/Cursor.php第 154 行中的数组到字符串转换"

下面是 Cursor.php 的第 154 行。MongoCursor::key 不将"_id"作为数组处理吗?

/** @proxy */
public function key()
{
    return $this->mongoCursor->key();
}

为了快速将 mongoDb 光标转换为数组,您可以使用 http://php.net/manual/en/function.iterator-to-array.php

$qb = $this->createQueryBuilder();
$qb->hydrate(false);
$query = $qb->getQuery();
$resultArray = iterator_to_array($query->execute());
key

() 总是返回一个字符串(参见 http://php.net/manual/en/class.iterator.php),因此它会生成该通知,尝试将数组转换为字符串形式。 这只是一个通知,不过,它应该仍然有效。

解决此问题的最简单方法可能是不要在游标上调用 toArray():而是遍历它 ( foreach $resultCursor as $value) ... )。