使用 Propel ORM (1.6.5),当我 joinWith() 一个表“A”到表“B”,然后在结果 PropelObjectCollection 上调用 toArray() 时,每个 A 记录中 B 的条目包含 A 的所有记录再次(见下面的转储)。
A 是 B 的 LEFT JOINd。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
...
我想停止这个,主要是因为有很多记录,并且通过递归,我很容易超过 PHP 的 512m memory_limit(我什至做了 2048m 的测试,仍然过去了)