40% de descuento en todos los planes

4d: 21h: 36m:45s'
Cómo solucionar el error "Specified key was too long error" en Laravel

Cómo solucionar el error "Specified key was too long error" en Laravel

Jorge García
Jorge García
Comparte:
Si estás buscando una solución para este error:
[Illuminate\Database\QueryException]
SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes (SQL: alter table users add unique users_email_unique(email))

[PDOException]
SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes
Podemos solucionarlo de 3 formas:
  1. Actualizar la versión de MySQL
  2. Modificar el archivo config/database
  3. Modificar el archivo  app/Providers/AppServiceProvider.php

Solución 1

Si utilizas MariaDB o versiones anteriores de MySQL v5.7.7 simplemente actualiza a la versión estable más reciente y no volverás a tener este problema.

Solución 2

Si no puedes o no quieres actualizar MySQL, intenta modificando el engine de mysql en el archivo config/database.php
'mysql' => [
    ...
    'engine' => 'InnoDB',
]

Solución 3

Si por algún motivo no te funciona la solución 2, agrega la siguiente línea al archivo  app/Providers/AppServiceProvider.php
use Illuminate\Support\Facades\Schema;

public function boot()
{
    Schema::defaultStringLength(191);
}

¿Por qué ocurre este error?

Desde la versión 5.4 de Laravel se realizó un cambio en el conjunto de caracteres predeterminado de la base de datos, y ahora es utf8mb4, que incluye soporte para almacenar emojis. 
Esto solo afecta a las aplicaciones que utilicen versiones anteriores a MySQL v5.7.7