我的szenario详细说明,我有一个用户文档:
/** @Document(collection="user") */
class User
{
/** @Id */
private $id;
/** @ReferenceMany(targetDocument="Pet") */
private $pet;
public function getPet()
{
return $this->pet;
}
}
并且我有一份宠物文件:
/** @Document(collection="pet") */
class Pet
{
/** @Id */
private $id;
/** @ReferenceMany(targetDocument="User") */
private $user;
public function getUser()
{
return $this->user;
}
}
多对多的相关性。如果我为现有文件调用以下代码......
$result = $this->_dbContainer->getDocumentManager()->getRepository('User')->findBy(array('id' => => 'XZTZHJ323LKFHGJKLHGFGHJK'));
print_r($result->toArray());
......它以无限循环结束。错误讯息:
PHP Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 112721921 bytes) in ...
如果我执行以下代码:
var_dump($result->count());
结果是一个/它存在(一切都好)。 $ result-> current()的var_dump为NULL。 getMongoData方法返回以下数据(这是正确的):
Array ( [0] => Array ( [$ref] => example [$id] => MongoId Object ( [$id] => 4ddac7667294c79e17000002 ) [$db] => test ) )
如果我执行以下代码:
var_dump($result->current());
结果是boolean(false)。
有什么想法吗?
答案 0 :(得分:1)
尝试再生水化器类。
答案 1 :(得分:0)
如果您的模型看起来像这样
/**
* @Document
*/
class User
{
/** @Id */
private $id;
/** @ReferenceMany(targetDocument="Something") */
private $somethings;
public function __construct()
{
$this->somethings = new \Doctrine\Common\Collections\ArrayCollection;
}
public function getSomethings()
{
return $this->somethings;
}
}
您应该能够使用
检索引用的模型$user = $dm->find('User', $id);
$somethings = $user->getSomethings();
$firstSomething = $somethings->current(); // will return false if empty, can also use first()
foreach ($somethings as $something) {
// and so on
}
请勿尝试var_dump()
或print_r()
模型代理对象。它们包含许多递归引用,您将耗尽可用内存,尝试将它们呈现为输出。
答案 2 :(得分:0)
从引用的集合中获取单个对象的解决方案:
$pets = $this->user->getPets();
if(!is_null($pets) && $pets->count() > 0) {
$this->pet = $pets->first();
}
最大的学习(感谢@Phil):
不要尝试var_dump()或 print_r()模型代理对象。 这些包含许多递归 参考,你会耗尽你的 尝试渲染的可用内存 它们作为输出。
祝你好运, 斯蒂芬