"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 > Laravel WhereIn y GroupBy: ¿Cómo resolver el error 1055 de MySQL?

Laravel WhereIn y GroupBy: ¿Cómo resolver el error 1055 de MySQL?

Publicado el 2024-12-21
Navegar:895

Laravel WhereIn and GroupBy: How to Resolve MySQL's 1055 Error?

Laravel: Error de sintaxis o infracción de acceso: Error 1055 al usar WhereIn y GroupBy

Para la recuperación de datos de una fila específica, Laravel nos permite utilice WhereIn y GroupBy en la misma consulta. Sin embargo, esto a veces puede resultar en un "Error de sintaxis o infracción de acceso: Error 1055".

Causas del error

Este error ocurre cuando:

  • El modo estricto está habilitado en la configuración de MySQL.
  • El campo de identificación, que se utiliza en la condición WhereIn, no está incluido en el campo GroupBy list.

Soluciones

Desactivar el modo estricto

Puedes desactivar el modo estricto de MySQL configurando 'estricto' => false en la matriz 'mysql' del archivo config/database.php.

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

Agregar modos a las opciones de MySQL

Alternativamente, puede dejar el modo estricto habilitado y agregar modos específicos a la opción 'modos' de la matriz 'mysql':

'mysql' => [
    ...
    'strict' => true,
    'modes' => ['STRICT_TRANS_TABLES'],
    ...
],

Incorpore el campo GroupBy en WhereIn

Asegúrese de que el campo de identificación utilizado en la condición WhereIn también esté incluido en la lista de campos GroupBy. Esto evitará que ocurra el error.

$loadids = explode("#@*", $reciptdet->loading_id);
$loadingdatas = DB::table('loading')
    ->groupBy(['vehicle_no', 'id'])
    ->whereIn('id', $loadids)
    ->get();

Al implementar estas soluciones, puede resolver el "Error de sintaxis o infracción de acceso: Error 1055" al utilizar WhereIn y GroupBy en la misma consulta.

Ú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