Om du använder createQueryBuilder kan du använda som
$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');
Observera att du måste ha "HIDDEN".
Du kan också göra med doktrinnative query.