如何在symfony2中的表单类型类中获取doctrine存储库?

时间:2012-03-15 05:08:11

标签: symfony formbuilder

$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类中使用上面的代码。我正在使用此查询为表单构建器中的选择类型生成数组。

1 个答案:

答案 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
}