Maison > développement back-end > tutoriel php > Comment résoudre l'erreur \'Expected Doctrine\\ORM\\Query\\Lexer::T_WITH, got \'ON\'\' lors des jointures gauches dans Doctrine ?

Comment résoudre l'erreur \'Expected Doctrine\\ORM\\Query\\Lexer::T_WITH, got \'ON\'\' lors des jointures gauches dans Doctrine ?

Susan Sarandon
Libérer: 2024-10-29 04:24:02
original
583 Les gens l'ont consulté

How to Resolve the

Comment effectuer des jointures à gauche dans Doctrine

Lorsque vous travaillez avec des modèles de données complexes, il devient nécessaire de récupérer les données de plusieurs tables en établissant des relations entre elles. Les jointures gauches vous permettent de récupérer toutes les lignes d'une table et uniquement les lignes correspondantes de l'autre table.

Problème rencontré

Une erreur courante qui peut survenir lors d'une tentative de jointure gauche dans Doctrine est la réception l'erreur de syntaxe suivante :

[Erreur de syntaxe] ligne 0, col 98 : Erreur : Doctrine attendueORMQueryLexer::T_WITH, obtenu 'ON'

Cette erreur se produit lorsque "ON" est utilisé dans le clause de jointure au lieu de "AVEC". Pour résoudre ce problème, remplacez « ON » par « WITH » comme indiqué ci-dessous :

<code class="php">$qb->leftJoin('User\Entity\User', 'u', \Doctrine\ORM\Query\Expr\Join::WITH, 'a.user = u.id')</code>
Copier après la connexion

Implémentation des jointures à gauche

Pour effectuer une jointure à gauche dans Doctrine, il existe deux approches :

Avec une association :

Si votre entité a une association avec la table que vous souhaitez rejoindre, vous pouvez utiliser la syntaxe suivante :

<code class="php">$qb
    ->select('a', 'u')
    ->from('Credit\Entity\UserCreditHistory', 'a')
    ->leftJoin('a.user', 'u')
    ->where('u = :user')
    ->setParameter('user', $users)
    ->orderBy('a.created_at', 'DESC');</code>
Copier après la connexion

Dans dans ce cas, "CreditEntityUserCreditHistory#user" représente l'association entre les deux entités.

Sans association :

Si aucune association n'existe, vous pouvez utiliser la syntaxe suivante :

<code class="php">$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');</code>
Copier après la connexion

Cette requête récupère les enregistrements des deux tables et renvoie un jeu de résultats contenant des tableaux au format suivant :

<code class="php">array(
    array(
        0 => UserCreditHistory instance,
        1 => Userinstance,
    ),
    array(
        0 => UserCreditHistory instance,
        1 => Userinstance,
    ),
    // ...
)</code>
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal