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
DDDasal
2024-12-20 11:00:11334semak imbas

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,
    ...
]

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'
    ],
    ...
]

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!

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