"إذا أراد العامل أن يؤدي عمله بشكل جيد، فعليه أولاً أن يشحذ أدواته." - كونفوشيوس، "مختارات كونفوشيوس. لو لينجونج"
الصفحة الأمامية > برمجة > كيفية حل تعارض SQL_MODE=ONLY_FULL_GROUP_BY في Laravel Eloquent؟

كيفية حل تعارض SQL_MODE=ONLY_FULL_GROUP_BY في Laravel Eloquent؟

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

How to Resolve SQL_MODE=ONLY_FULL_GROUP_BY Conflict in Laravel Eloquent?

حل تعارض SQL_MODE=ONLY_FULL_GROUP_BY في Laravel Eloquent

عند استخدام Eloquent لإجراء استعلام مجموعة حسب، قد تواجه خطأ يتعلق بـ الإعدادات غير المتوافقة لـ sql_mode=only_full_group_by. يمكن أن يحدث هذا الخطأ عند تضمين أعمدة غير مجمعة في قائمة SELECT والتي لا تشكل جزءًا من جملة GROUP BY.

لحل هذه المشكلة، يمكنك تعطيل وضع MySQL الصارم عن طريق تعيين ما يلي في قاعدة البيانات الخاصة بك ملف التكوين:

'connections' => [
    'mysql' => [
        'strict' => false,
    ]
]

من خلال تعيين "صارم" على خطأ، فإنك تسمح لـ MySQL بالتصرف كما لو كانت تعمل في وضع MySQL 5.6، والذي لا يفرض قواعد التجميع الصارمة التي يفرضها sql_mode=only_full_group_by.

بدلاً من ذلك، يمكنك تعديل استعلام Eloquent الخاص بك للتأكد من أن جميع الأعمدة في قائمة SELECT إما مجمعة أو مضمنة في جملة GROUP BY. على سبيل المثال، يمكنك استخدام الطريقة "الخام" لإضافة التجميع الضروري:

]&&&]$products = Product::where('status', 1) ->أين ('المخزون'، '>'، 0) ->حيث ('category_id'، '='، $category_id) ->groupBy('store_id') ->orderBy('updated_at', 'desc') ->selectRaw('*, COUNT(*) AS Total_products') ->خذ (4) ->الحصول على ()؛
            
بيان الافراج أعيد طبع هذه المقالة على: 1729224796 في حالة وجود أي مخالفة، يرجى التواصل مع [email protected] لحذفها
أحدث البرنامج التعليمي أكثر>

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

Copyright© 2022 湘ICP备2022001581号-3