4

我的模型中有一个 Doctrine 查询,说 Model_1Table.class.php 与 Model_2 连接。Model_2 在多对一关系上与 Model_1 相关。(它确实是一对一的关系,而不是多对一的关系,但架构是这样设计的)

我的查询是:

$this->select('m1.*, m2.primaryKeyOfModel2')->leftJoin('m1.model2 m2')->where('m1.record = ?', some_value);

检查 SF 调试器日志,它按应有的方式检索信息,保留 Model_1 中满足 where 子句的所有表记录,并保留 Model_2 的所有值以及那些不存在的空值。

当我想访问此信息并根据表中是否存在 model_2 记录有条件地呈现信息时,痛苦就开始了。我喜欢这样:

<?php foreach($Model1Records as $Model1Record) :
          if($Model1Record->getModel2()) :
              foreach($Model1Record->getModel2() as $Model2Record):
                        //do something 
               end foreach ; 
          else: //basically checking for if(!($Model1Record->getModel2()))
              // do something else
           endif;
    endforeach ; ?>

现在基于此它应该真的可以工作,但我认为正在发生的事情是对于 model2 的空值它失败了。我该如何推断,因为如果我删除上述记录中的 if-else 语句并简单地使用 foreach 循环访问 Model2Record 的集合,则检索 Model2Record 中的可用行,但是它当然不会访问空值. 从本质上讲,我从中获得的信息就是我通常从内部连接中获得的信息。

要提出一个问题,我如何访问 Model1 的记录,其中 Model2 记录为空值?

4

1 回答 1

3

不确定通过学说模型1和模型2之间的空关系的默认返回是什么,但显然它没有返回false,否则你会遇到else条件,请尝试'instanceof',例如:

<?php foreach($Model1Records as $Model1Record) :

      if($Model1Record->getModel2() instanceof Model2) :

您还可以尝试将 Model1 对象转换为数组:

<?php foreach($Model1Records as $Model1Record) :

    <?php $model1 = $Model1Record->toArray();  ?>

      if(isset($model1['Model2'])) :

- 更新 -

如果它返回一个 Doctrine_Collection 实例,你应该能够做到:

<?php foreach($Model1Records as $Model1Record) :

      if($Model1Record->getModel2()->count() > 0) :
于 2012-08-18T23:46:58.207 回答