$repository = $this->getDoctrine()->getRepository('ParabolaEntityBundle:ProjectAllocation');
$query = $repository->createQueryBuilder('p')
->where('p.startDate < :sdate and p.employee = :emp and p.endDate > :edate')
->setParameter('sdate', date('Y-m-d', time()))
->setParameter('edate', date('Y-m-d', time()))
->setParameter('emp', $employee->getId())
->getQuery();
$projectAllocate = $query->getResult();
我如何在FormType类中使用上面的代码。我正在使用此查询为表单构建器中的选择类型生成数组。
答案 0 :(得分:6)
我认为你应该使用entity
类型而不是query_builder
选项。
此链接:
http://symfony.com/doc/current/reference/forms/types/entity.html
描述如何做到这一点。
如果由于某种原因你真的不想使用entity
类型,你总是可以在控制器中检索数据并通过FormType
构造函数传递它,这有点快'n'很脏,但应该工作得很好......
<强>控制器:强>
$this->createForm(new MyFormType($results_from_qb), $form_data );
<强> FormType:强>
public function __construct($results_from_qb){
$this->results_from_qb = $results_from_qb; // store it into class member field to be used latter in buildForm method
}