Pokud používáte createQueryBuilder, můžete použít jako
$query->addSelect("(CASE WHEN name like 'John %' THEN 0
WHEN name like 'John%' THEN 1
WHEN name like '% John%' THEN 2
ELSE 3 END) AS HIDDEN ORD ");
$query->orderBy('ORD', 'DESC');
Všimněte si, že musíte mít "HIDDEN".
Vystačíte si také s nativním dotazem doktríny.