我正试图以这种方式搜索存储在数组中的单词:
$dql_cat =' SELECT c
FROM FrontendBundle:Categoria c
WHERE';
foreach ($palabras as $palabra){
if ($palabra === reset($palabras)){
$dql_cat .= ' c.nombre LIKE %'.$palabra.'%';
}
else{
$dql_cat .= ' OR c.nombre LIKE %'.$palabra.'%';
}
}
$dql_cat .= ' ORDER BY c.nombre';
$query = $em->createQuery($dql_cat);
$resultados['categorias'] = $query->getResult();
但我在查询时遇到异常。
查询结果:
SELECT c FROM FrontendBundle:分类c 在哪里c.nombre LIKE%carpinteria%OR c.nombre LIKE%aluminio%ORDER BY c.nombre
查询例外:
QueryException:[语法错误]第0行,第98行:错误:预期的StateFieldPathExpression |字符串| InputParameter | FunctionsReturningStrings | AggregateExpression,得到'%'
我认为使用queryBuilder避免错误更合适,但我不知道如何将它与参数数组一起使用。
我需要有或没有queryBuilder的解决方案。
感谢。
答案 0 :(得分:0)
首先应该引用%$palabra%
,对吧?:
foreach ($palabras as $palabra){
if ($palabra === reset($palabras)){
$dql_cat .= " c.nombre LIKE '%".$palabra."%'";
}
else{
$dql_cat .= " OR c.nombre LIKE '%".$palabra."%'";
}
}
答案 1 :(得分:0)
queryBuilder如下:
$qb = $em->createQueryBuilder();
$qb->select('c')
->from('FrontendBundle:Categoria', 'c');
foreach ($palabras as $palabra){
if ($palabra === reset($palabras)){
$qb->where($qb->expr()->like('c.nombre', $qb->expr()->literal('%' . $palabra . '%')));
}
$qb->orWhere($qb->expr()->like('c.nombre', $qb->expr()->literal('%' . $palabra . '%')));
}
$query = $qb->orderBy('c.nombre', 'ASC')
->getQuery();
$resultados['categorias'] = $query->getResult();