Рендер ветки symfony2, выброшено исключение

Итак, в моем базовом шаблоне у меня есть: {% render "EcsCrmBundle:Module:checkClock" %}

Затем я создал ModuleController.php...

<?php

namespace Ecs\CrmBundle\Controller;

use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Ecs\CrmBundle\Entity\TimeClock;

class ModuleController extends Controller
{
    public function checkClockAction() {
        $em = $this->getDoctrine()->getEntityManager();
        $user = $this->get('security.context')->getToken()->getUser();
        $today = time();
        $start = date('Y-m-d 00:00:00');
        $entities = $em->getRepository('EcsCrmBundle:TimeClock');
        $query = $entities->createQueryBuilder('tc')
                ->select('tc.in1, tc.out1, tc.in2, tc.out2, tc.in3, tc.out3')
                ->where('tc.noteBy = :user')
                ->andWhere('tc.daydate >= :start')
                ->setParameter('user', $user->getid())
                ->setParameter('start', $start)
                ->setMaxResults('1')
                ->getQuery();
         $entities = $query->getSingleResult();
         if (empty($entities)) {
            $ents = "clocked_out";
            $this->get('session')->set('clockedin', 'clocked_out');
         } else {
            for ($i=1; $i <= 3; $i++) {
                if ($entities["in$i"] != NULL) {
                    $ents = "clocked_in";
                    if ($i == 1) {
                        $this->get('session')->set('nextclock', "out$i");
                    } else {
                        $x = $i+1;
                        $this->get('session')->set('nextClock', "out$x");
                    }
                    if ($entities["out$i"] != NULL) {
                        $ents = "clocked_out";
                        $x = $i+1;
                        $this->get('session')->set('nextclock', "in$x");
                    }
                    if ($entities["out3"] != NULL) {
                        $ents = "day_done";
                    }
                }
            }
         }
        return $this->render('EcsCrmBundle:Module:topclock.html.twig', array(
            'cstat' => $ents,
        ));
    }
}

Проблема в том, что если в базе данных на конкретный день для конкретного пользователя еще ничего нет... я продолжаю получать:

An exception has been thrown during the rendering of a template ("No result was found for query although at least one row was expected.") in ::base.html.twig at line 161.
500 Internal Server Error - Twig_Error_Runtime
1 linked Exception: NoResultException »

Я знаю, что это как-то связано с тем фактом, что это не "результат" из базы данных... но разве это не то, чего я добился, имея if (empty($entities)) { ?? Я понятия не имею, как это исправить... любая помощь приветствуется...


person Johnny    schedule 03.04.2012    source источник


Ответы (1)


Заменять:

$entities = $query->getSingleResult();

С участием

$entity = $query->getOneOrNullResult();

Если вы посмотрите в Doctrine\ORM\AbstractQuery, вы увидите, что getSingleResult ожидает один и только один результат. 0 будет через исключение.

Я посмотрел на ваш код немного более внимательно, и похоже, что вы действительно ожидаете массив сущностей. в этом случае используйте:

$entities = $query->getResult();
person Cerad    schedule 03.04.2012
comment
Хороший! Я имел дело с очень похожей проблемой, и вы решили ее для меня.. +1 за OP и +1 за Cerad! - person Justin; 03.04.2012