Bagaimana untuk Menyelesaikan \'Doktrin yang Diharapkan\\ORM\\Query\\Lexer::T_WITH, mendapat Ralat \'HIDUP\'\' Semasa Menyertai Kiri dalam Doktrin?

Susan Sarandon
Lepaskan: 2024-10-29 04:24:02
asal
520 orang telah melayarinya

How to Resolve the

Cara Melakukan Left Joins dalam Doktrin

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.

Isu Ditemui

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>
Salin selepas log masuk

Melaksanakan Gabungan Kiri

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan