createQueryBuilder Query Working fine Form, когда я пытаюсь написать пользовательский запрос с использованием EntityManager с его предупреждением. EntityManager недоступен.Пользовательский запрос в форме Symfony
Контроллер:
$form = $this->createForm(new ContractsType($user, $isAdmin, $securityContext), $contract, array('em' => $em, 'referring_student' => $contract->getReferringStudent()));
ContractsType
class ContractsType extends AbstractType {
$queryBuilder = function($repo) use ($user) {
return $repo->createQueryBuilder('p')
->leftJoin('p.employees', 'e')
->where('e.id = :employee_id')
->setParameter('employee_id', $user->getId())
->orderBy('p.name', 'ASC');
}
$builder->add('store', 'entity', array(
'class' => 'C2EducateToolsBundle:Stores',
'label' => 'Center',
'query_builder' => $queryBuilder,
'property' => 'name',
'empty_value' => 'Select')
);
}
createQueryBuilder работает отлично, но я хочу, чтобы написать пользовательский запрос, используя EntityManager, Как я могу сделать объект Equery доступны здесь. так что я могу запустить ниже запрос.
$storesQuery = "select store_id as id,ts.name as name from tbl_employees e LEFT JOIN tbl_stores ts ON e.store_id=ts.id where e.id=:employeesId AND ts.center_type_id!=:centerTypeId AND ts.select_option = :selectOption";
$em = $this->getDoctrine()->getEntityManager();
$stmt = $em->getConnection()->prepare($storesQuery);
$stmt->bindValue('employeesId', $user->getId());
$stmt->execute();
$listLocations = $stmt->fetchAll(\PDO::FETCH_ASSOC);
Произвольный [репозиторий класса] (http://symfony.com/doc/current/doctrine/repository.html)? – Unflux
Вы могли решить вашу проблему? – Rhono