Chcę użyć właściciela miejsca parametru - np. ? 1 - z% dzikich kart. to jest coś w stylu: "u.name LIKE%? 1%" (chociaż to powoduje błąd). Docs mają następujące dwa przykłady: 1.doctrine2 dql, użyj setParameter z% wildcard podczas porównywania
// Example - $qb->expr()->like('u.firstname', $qb->expr()->literal('Gui%'))
public function like($x, $y); // Returns Expr\Comparison instance
nie podoba mi się to, ponieważ nie ma ochrony przed wstrzyknięciem kodu.
2.
// $qb instanceof QueryBuilder
// example8: QueryBuilder port of: "SELECT u FROM User u WHERE u.id = ?1 OR u.nickname LIKE ?2 ORDER BY u.surname DESC" using QueryBuilder helper methods
$qb->select(array('u')) // string 'u' is converted to array internally
->from('User', 'u')
->where($qb->expr()->orx(
$qb->expr()->eq('u.id', '?1'),
$qb->expr()->like('u.nickname', '?2')
))
->orderBy('u.surname', 'ASC'));
nie podoba mi się to, bo trzeba szukać wewnątrz względem właściwości obiektu - to znaczy, muszę dzikie karty na obu stronach.
doskonała odpowiedź, właśnie tego, czego szukałem, dziękuję – waigani
czy mógłbyś głosować w górę lub zaakceptować to jako odpowiedziano? –
co się stanie, jeśli '$ value = '\\''? – seyed