「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Doctrine での左結合中の「予期された Doctrine\\ORM\\Query\\Lexer::T_WITH、\'ON\' を取得しました」エラーを解決するにはどうすればよいですか?

Doctrine での左結合中の「予期された Doctrine\\ORM\\Query\\Lexer::T_WITH、\'ON\' を取得しました」エラーを解決するにはどうすればよいですか?

2024 年 11 月 8 日に公開
ブラウズ:639

How to Resolve the \

Doctrine で左結合を実行する方法

複雑なデータモデルを扱う場合、テーブル間の関係を確立して複数のテーブルからデータを取得する必要があります。左結合を使用すると、一方のテーブルからすべての行をフェッチし、もう一方のテーブルから一致する行のみをフェッチできます。

問題が発生しました

Doctrine で左結合を試行すると発生する可能性のある一般的なエラーが受信されます次の構文エラー:

[Syntax Error] line 0、col 98: Error: Expected Doctrine\ORM\Query\Lexer::T_WITH, got 'ON'

このエラーは、「」の場合に発生します。結合句では「WITH」の代わりに「ON」が使用されます。これを解決するには、以下に示すように、「ON」を「WITH」に置き換えます。

$qb->leftJoin('User\Entity\User', 'u', \Doctrine\ORM\Query\Expr\Join::WITH, 'a.user = u.id')

左結合の実装

Doctrine で左結合を実行するには、2 つのアプローチがあります:

関連付けあり:

エンティティに結合したいテーブルとの関連付けがある場合は、次の構文を使用できます:

$qb
    ->select('a', 'u')
    ->from('Credit\Entity\UserCreditHistory', 'a')
    ->leftJoin('a.user', 'u')
    ->where('u = :user')
    ->setParameter('user', $users)
    ->orderBy('a.created_at', 'DESC');

この場合、「Credit\Entity\UserCreditHistory#user」は 2 つのエンティティ間の関連付けを表します。

関連付けなし:

関連付けが存在しない場合は、次の構文を使用できます:

$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');

このクエリは両方のテーブルからレコードを取得し、次の形式の配列を含む結果セットを返します:

array(
    array(
        0 => UserCreditHistory instance,
        1 => Userinstance,
    ),
    array(
        0 => UserCreditHistory instance,
        1 => Userinstance,
    ),
    // ...
)
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3