我是Symfony的新手,在运行查询时遇到了错误:
public function getFilteredArticles($page, $nbPerPage, $data) {
$query = $this->createQueryBuilder('a')
->leftJoin('a.images', 'i')
->addSelect('i')
->leftJoin('a.type_stockage', 't')
->addSelect('t')
->leftJoin('a.famille', 'f')
->addSelect('f');
if ($data['famille'] != '') {
$query->where('f.id = :famille')
->setParameter('famille', $data['famille']);
}
if ($data['rds'] == false) {
$query->where('a.stock_actuel > 0');
}
if ($data['recherche'] != '' && $data['recherche'] != null) {
$query->where('a.ref_article LIKE :recherche')
->setParameter('recherche', '%' . $data['recherche'] . '%');
}
$query->leftJoin('a.sousfamille', 's')
->orderBy('a.ref_article', 'ASC')
->getQuery();
$query->setFirstResult(($page - 1) * $nbPerPage)
->setMaxResults($nbPerPage);
return new Paginator($query, true);
}
这个查询有条件参数,可以看到它返回了我需要的文章列表。但是当我运行这个查询来填充我的表格时,我得到了一个错误信息:
“在模板渲染期间引发了异常(“参数过多:查询定义了0个参数,而您绑定了1个”)”。
我不知道为什么他期望0个参数。我尝试使用setParameters,但结果仍然相同。
有人有想法吗?