带连接的Doctrine查询。获得结果

时间:2015-05-03 21:30:18

标签: php doctrine-orm zend-framework2 doctrine-query

我无法从查询中获得结果。

这是控制器方法:

public function indexAction()
{
    $this->layout()->setVariable('page_title', 'Страницы');
    $pages = $this->getServicePage()->getPageList($type = 1);
    $viewModel = new ViewModel(['pages' => $pages]);
    return $viewModel;
}

我使用服务:

public function getPageList($type){
    $language = $this->entityManager
        ->getRepository('\ApanelLanguage\Entity\LanguageCommon')
        ->findOneBy(['LanguageMain' => 1]);

    $pages = $this->entityManager
        ->getRepository('\ApanelPage\Entity\PageCommon')
        ->getPagesList($type, $language->getLanguageId());
    return $pages;
}

这是Reporitory代码:

public function getPagesList($type, $language)
{
    $qb = $this->_em->createQueryBuilder()
        ->select(['u','p'])
        ->from('ApanelPage\Entity\PageCommon', 'u')
        ->innerJoin('ApanelPage\Entity\PageData','p', 'WITH', 'u.PageId = p.PageCommonId')
        ->where('u.PageTypeId = :type')
        ->andWhere('p.PageLanguageId = :language')
        ->setParameter('type', $type)
        ->setParameter('language', $language);
    return $qb->getQuery()->getResult();
} 

如果我试图在视野中获得结果

<?php  $i=0;
foreach ($this->pages as $page) {
    $i++;
    echo $id       = $page->getPageId();
    echo $cid       = $page->getPageCommonId();
} ?>

我收到错误

  

致命错误:调用未定义的方法   ApanelPage \ Entity \ PageCommon :: getPageCommonId()in   /home/xtadmin/localhost/test.zend/www/module/ApanelPage/view/apanel-page/page/index.phtml   第19行

我尝试了不同的变体,但它试图在错误的实体中找到方法。

P.S。如果它试试这个:

echo "<pre>";
var_dump($pages);
echo "</pre>";

我的firefox挂断了,我必须杀死这个进程。

更新 实体/ PageData.php

...
 /**
 * @var Pagecommon
 * @ORM\ManyToOne(targetEntity="ApanelPage\Entity\PageCommon")
 * @ORM\JoinColumns({
 *   @ORM\JoinColumn(name="PageCommonId", referencedColumnName="PageId")
 * })
 */
protected $PageCommonId;
...
public function getPageCommonId() { return $this->PageCommonId; }
public function setPageCommonId($PageCommonId) { $this->PageCommonId = (int)$PageCommonId;}
...

1 个答案:

答案 0 :(得分:0)

您认为getPageCommonId方法位于您的PageData实体中,但错误是因为它试图在您的PageCommon实体中找到此方法:

  

调用未定义的方法ApanelPage\Entity\PageCommon::getPageCommonId()

我认为你的方法在错误的地方。