"إذا أراد العامل أن يؤدي عمله بشكل جيد، فعليه أولاً أن يشحذ أدواته." - كونفوشيوس، "مختارات كونفوشيوس. لو لينجونج"
الصفحة الأمامية > برمجة > كيفية إصلاح الخطأ \"التعبير رقم 1 في قائمة SELECT ليس في جملة GROUP BY\" في Laravel Eloquent بسبب الوضع الصارم لـ MySQL؟

كيفية إصلاح الخطأ \"التعبير رقم 1 في قائمة SELECT ليس في جملة GROUP BY\" في Laravel Eloquent بسبب الوضع الصارم لـ MySQL؟

تم النشر بتاريخ 2024-11-08
تصفح:590

How to Fix \

عدم التوافق مع sql_mode=only_full_group_by في Laravel Eloquent

مواجهة الخطأ "التعبير رقم 1 في قائمة SELECT ليس في جملة GROUP BY.. ." عند تنفيذ استعلام Eloquent بالتجميع يشير إلى عدم توافق مع MySQL sql_mode=only_full_group_by. لحل هذه المشكلة:

تعطيل وضع MySQL الصارم

أحد الحلول هو تعطيل إعداد وضع MySQL الصارم في تكوين اتصال قاعدة البيانات الخاصة بك. في ملف Laravel .env، أضف السطر التالي:

DB_STRICT_MODE=false
DB_STRICT_MODE=false
بدلاً من ذلك، يمكنك تكوين الوضع الصارم في ملف config/database.php:

'mysql' => [
    // Disable strict mode
    'strict' => false,
],

شرح

في MySQL 5.7 والإصدارات الأحدث، يتطلب وضع sql_mode=only_full_group_by أن يتم تضمين كافة الأعمدة في قائمة SELECT إما في عبارة GROUP BY أو أن تكون وظائف مجمعة. في الاستعلام المقدم:

$products = Product::where('status', 1)
            ->where('stock', '>', 0)
            ->where('category_id', '=', $category_id)
            ->groupBy('store_id')
            ->orderBy('updated_at', 'desc')
            ->take(4)
            ->get();
يظهر معرف العمود (المفتاح الأساسي) في قائمة SELECT ولكن لم يتم تضمينه في جملة GROUP BY. من خلال تعطيل الوضع الصارم، سيسمح MySQL بالأعمدة غير المجمعة في قائمة SELECT والتي لا تعتمد وظيفيًا على أعمدة GROUP BY.

بيان الافراج أعيد طبع هذه المقالة على: 1729224679 في حالة وجود أي انتهاك، يرجى الاتصال بـ [email protected] لحذفها
أحدث البرنامج التعليمي أكثر>

تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.

Copyright© 2022 湘ICP备2022001581号-3