Apabila bekerja dengan model data yang kompleks, adalah perlu untuk mendapatkan semula data daripada berbilang jadual dengan mewujudkan perhubungan antara mereka. Gabungan kiri membolehkan anda mengambil semua baris dari satu jadual dan hanya baris yang sepadan dari jadual yang lain.
Ralat biasa yang mungkin timbul apabila cuba gabungan kiri dalam Doktrin sedang menerima ralat sintaks berikut:
[Ralat Sintaks] baris 0, kol 98: Ralat: DoktrinORMQueryLexer yang dijangkakan::T_WITH, mendapat 'ON'
Ralat ini berlaku apabila "ON" digunakan dalam sertai klausa dan bukannya "WITH." Untuk menyelesaikan masalah ini, gantikan "HIDUP" dengan "DENGAN" seperti yang ditunjukkan di bawah:
<code class="php">$qb->leftJoin('User\Entity\User', 'u', \Doctrine\ORM\Query\Expr\Join::WITH, 'a.user = u.id')</code>
Untuk melakukan gabungan kiri dalam Doktrin, terdapat dua pendekatan:
Dengan Persatuan:
Jika entiti anda mempunyai perkaitan dengan jadual yang anda ingin sertai, anda boleh menggunakan sintaks berikut:
<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>
Dalam kes ini, "CreditEntityUserCreditHistory#user" mewakili perkaitan antara dua entiti.
Tanpa Persatuan:
Jika tiada perkaitan wujud, anda boleh menggunakan sintaks berikut:
<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>
Pertanyaan ini mendapatkan semula rekod daripada kedua-dua jadual dan mengembalikan set hasil yang mengandungi tatasusunan format berikut:
<code class="php">array( array( 0 => UserCreditHistory instance, 1 => Userinstance, ), array( 0 => UserCreditHistory instance, 1 => Userinstance, ), // ... )</code>
Atas ialah kandungan terperinci Bagaimana untuk Menyelesaikan \'Doktrin yang Diharapkan\\ORM\\Query\\Lexer::T_WITH, mendapat Ralat \'HIDUP\'\' Semasa Menyertai Kiri dalam Doktrin?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!