Comment effectuer des jointures à gauche dans Doctrine
Dans votre fonction getHistory(), vous tentez de récupérer l'historique de crédit d'un utilisateur . Cependant, la syntaxe initiale de votre clause de jointure a entraîné une erreur.
Pour effectuer une jointure gauche dans Doctrine, vous pouvez utiliser la syntaxe suivante :
$qb
->select('a', 'u')
->from('Credit\Entity\UserCreditHistory', 'a')
->leftJoin('a.user', 'u')
->where('u = :user')
->setParameter('user', $users)
->orderBy('a.created_at', 'DESC');
Ici, a représente l'alias de l'entité UserCreditHistory et u représente l'alias de l'entité User rejointe. En utilisant la méthode leftJoin(), vous spécifiez que vous souhaitez inclure les lignes de la table User qui ne correspondent pas à la table UserCreditHistory.
Alternativement, si vous n'avez pas d'association entre les deux entités, vous pouvez utiliser la syntaxe suivante :
$qb
->select('a', 'u')
->from('Credit\Entity\UserCreditHistory', 'a')
->leftJoin(
'User\Entity\User',
'u',
\Doctrine\ORM\Query\Expr\Join::WITH,
'a.user = u.id'
)
->where('u = :user')
->setParameter('user', $users)
->orderBy('a.created_at', 'DESC');
````
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3