Я хочу объединить много строк с помощью DQL, но при попытке выдает сообщение об ошибке.
Мой код:
$qb = $this->_em->createQueryBuilder();
$qb->select('u')
->from(Tutore::class, 'u')
->andWhere($qb->expr()->concat($qb->expr()->concat('u.nom', $qb->expr()->literal(' ')), 'u.prenom'), ':fullname')
->andWhere($qb->expr()->eq('u.ancien', 0))
->setParameter('fullname', $fullname);
return $qb->getQuery()->getOneOrNullResult();
Сообщение об ошибке:
Uncaught PHP Exception Doctrine\ORM\Query\QueryException: "[Syntax Error] line 0, col 77: Error: Expected =, <, <=, <>, >, >=, !=, got 'AND'" at /vendor/doctrine/orm/lib/Doctrine/ORM/Query/QueryException.php line 54
Я также попытался заменить это:
$qb->expr()->literal(' '))
По простому: "".
Фактически, вы можете использовать where и andWhere без всякой разницы






Очень простой:
->andWhere("concat(u.nom, ' ', u.prenom) = :fullname")
.............................................................................
Есть ли способ сделать это с помощью функций doctrine expr?
Я считаю, что это неплохо. Это работа с запросами для вас?
Первое предложение должно быть с where, а не andWhere