Rumah > pembangunan bahagian belakang > tutorial php > Laravel WhereIn dan GroupBy: Bagaimana untuk Membetulkan 'Ralat sintaks atau pelanggaran akses: 1055'?

Laravel WhereIn dan GroupBy: Bagaimana untuk Membetulkan 'Ralat sintaks atau pelanggaran akses: 1055'?

DDD
Lepaskan: 2024-12-20 11:00:11
asal
351 orang telah melayarinya

Laravel WhereIn and GroupBy: How to Fix

Laravel: Menyelesaikan "Ralat sintaks atau pelanggaran akses: 1055 Ralat" Apabila Menggunakan WhereIn dan GroupBy

Dalam Laravel, isu biasa timbul apabila cuba menggabungkan WhereIn dan Kaedah GroupBy dalam satu pertanyaan, mengakibatkan "Ralat sintaks atau pelanggaran akses: Ralat 1055".

Untuk menangani ralat ini, pertimbangkan pilihan berikut:

Lumpuhkan Mod Ketat

Dalam fail config/database.php, cari tatasusunan konfigurasi sambungan MySQL . Tambahkan baris berikut:

'mysql' => [
    ...
    'strict' => false,
    ...
]
Salin selepas log masuk

Dengan menetapkan ketat kepada palsu, semua pilihan ketat akan dilumpuhkan, membenarkan pertanyaan untuk dilaksanakan tanpa menghadapi ralat.

Dayakan Mod Ketat Khusus

Sebagai alternatif, anda boleh secara terpilih mendayakan mod ketat tertentu sambil memastikan mod ketat umum didayakan. Tambahkan baris berikut:

'mysql' => [
    ...
    'strict' => true,
    'modes' => [
        // 'ONLY_FULL_GROUP_BY', // Disable this to allow grouping by one column
        'STRICT_TRANS_TABLES',
        'NO_ZERO_IN_DATE',
        'NO_ZERO_DATE',
        'ERROR_FOR_DIVISION_BY_ZERO',
        'NO_AUTO_CREATE_USER',
        'NO_ENGINE_SUBSTITUTION'
    ],
    ...
]
Salin selepas log masuk

Dalam kes ini, mod ONLY_FULL_GROUP_BY dilumpuhkan, membenarkan pengumpulan mengikut satu lajur manakala mod ketat yang lain kekal aktif.

Dengan melaksanakan penyelesaian ini, anda boleh menyelesaikan ralat "Ralat sintaks atau pelanggaran akses: 1055" dan berjaya melaksanakan pertanyaan anda dengan menggabungkan WhereIn dan GroupBy.

Atas ialah kandungan terperinci Laravel WhereIn dan GroupBy: Bagaimana untuk Membetulkan 'Ralat sintaks atau pelanggaran akses: 1055'?. 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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan