使用Propel ORM(1.6.5),当我加入()一个表" A"到表" B"然后在结果PropelObjectCollection上调用toArray(),每个A记录中B的条目再次包含A的所有记录(参见下面的转储)。
A是LEFT JOINd到B. A中的每个记录都指向B中的一个。我正在使用的代码:
$oAQuery = AQuery::create()
->joinB('b', Criteria::LEFT_JOIN)
->useBQuery()
->_if(strlen($sB))
->filterByBField1(str_replace(' ', '%', $sCity))
->_endif()
->endUse()
->with('b');
$oCollection = $oAQuery->find();
$aArray = $oAQuery->toArray();
toArray()转储:
Array
(
[0] => Array
(
[Field1] => 29
[Field2] => 0
[B] => Array
(
[BField1] => 7
[BField2] => 10
[As] => Array
(
[A_0] => *RECURSION*
[A_1] => Array
(
[Field1] = 234
[Field2] = 3424
...
我想要停止这一点,主要是因为有很多记录和递归我很容易超过512m memory_limit for PHP(我甚至做了2048m的测试,仍然过去了)
答案 0 :(得分:0)
您可以编写自己的格式化程序,以便决定如何处理结果集:http://www.propelorm.org/reference/model-criteria.html#using_an_alternative_formatter。
使用自定义格式化程序需要额外的方法调用:
$aArray = $oAQuery->setFormatter('MyCustomFormatter')->find();
// instead of $aArray = $oAQuery->toArray();