Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk Menyelesaikan \'Doktrin yang Diharapkan\\ORM\\Query\\Lexer::T_WITH, mendapat Ralat \'HIDUP\'\' Semasa Menyertai Kiri dalam Doktrin?

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

Susan Sarandon
Susan Sarandonasal
2024-10-29 04:24:02529semak imbas

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>

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>

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!

Kenyataan:
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