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