Cara Melakukan Left Joins in Doctrine
Dalam fungsi getHistory(), anda cuba mendapatkan semula sejarah kredit pengguna . Walau bagaimanapun, sintaks awal dalam klausa gabungan anda telah mengakibatkan ralat.
Untuk melaksanakan gabungan kiri dalam Doktrin, 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>
Di sini, a mewakili alias untuk entiti UserCreditHistory dan u mewakili alias untuk entiti Pengguna yang disertai. Dengan menggunakan kaedah leftJoin(), anda menyatakan bahawa anda ingin memasukkan baris daripada jadual Pengguna yang tidak sepadan dalam jadual UserCreditHistory.
Sebagai alternatif, jika anda tidak mempunyai perkaitan antara kedua-dua entiti, 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>
Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Gabungan Kiri dalam Doktrin untuk Mendapatkan Sejarah Kredit?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!