1

使用 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 的测试,仍然过去了)

4

1 回答 1

0

您可以编写自己的格式化程序,以便决定如何处理结果集: http: //www.propelorm.org/reference/model-criteria.html#using_an_alternative_formatter

使用自定义格式化程序需要额外的方法调用:

$aArray = $oAQuery->setFormatter('MyCustomFormatter')->find();
// instead of $aArray = $oAQuery->toArray();
于 2012-06-25T09:02:06.203 回答