"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > ¿Cómo resolver el conflicto SQL_MODE=ONLY_FULL_GROUP_BY en Laravel Eloquent?

¿Cómo resolver el conflicto SQL_MODE=ONLY_FULL_GROUP_BY en Laravel Eloquent?

Publicado el 2024-11-04
Navegar:360

How to Resolve SQL_MODE=ONLY_FULL_GROUP_BY Conflict in Laravel Eloquent?

Resolviendo SQL_MODE=ONLY_FULL_GROUP_BY Conflicto en Laravel Eloquent

Al usar Eloquent para realizar una consulta agrupada, puede encontrar un error relacionado con configuraciones incompatibles para sql_mode=only_full_group_by. Este error puede ocurrir cuando se incluyen columnas no agregadas en la lista SELECT que no forman parte de la cláusula GROUP BY.

Para resolver este problema, puede deshabilitar el modo MySQL estricto configurando lo siguiente en su base de datos archivo de configuración:

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

Al establecer 'estricto' en falso, permite que MySQL se comporte como si se estuviera ejecutando en modo MySQL 5.6, lo que no aplica las estrictas reglas de agrupación impuestas por sql_mode=only_full_group_by.

Alternativamente, puede modificar su consulta de Eloquent para asegurarse de que todas las columnas de la lista SELECT estén agregadas o incluidas en la cláusula GROUP BY. Por ejemplo, podría utilizar el método 'sin procesar' para agregar la agregación necesaria:

$products = Product::where('status', 1)
    ->where('stock', '>', 0)
    ->where('category_id', '=', $category_id)
    ->groupBy('store_id')
    ->orderBy('updated_at', 'desc')
    ->selectRaw('*, COUNT(*) AS total_products')
    ->take(4)
    ->get();
Declaración de liberación Este artículo se reimprime en: 1729224796 Si hay alguna infracción, comuníquese con [email protected] para eliminarla.
Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3