"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Comment implémenter les jointures à gauche dans la doctrine de récupération des antécédents de crédit ?

Comment implémenter les jointures à gauche dans la doctrine de récupération des antécédents de crédit ?

Publié le 2024-11-08
Parcourir:528

How to Implement Left Joins in Doctrine for Credit History Retrieval?

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');
````
Dernier tutoriel Plus>

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