当前位置: 代码迷 >> 综合 >> Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes的解决方式
  详细解决方案

Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes的解决方式

热度:39   发布时间:2023-11-25 02:30:20.0

Laravel 5.4对默认数据库字符集进行了更改,现在utf8mb4它包含了对存储表情符号的支持。这只会影响新的应用程序,只要您运行MySQL v5.7.7及更高版本,就不需要做任何事情。

对于运行MariaDB或旧版MySQL的用户,在尝试运行迁移时可能会遇到此错误:

[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]:语法错误或访问冲突:1071指定密钥太长; 最大密钥长度为767字节

正如迁移指南中所述,要解决此问题,您只需编辑 AppServiceProvider.php文件并在 boot方法内设置默认字符串长度:

use Illuminate\Support\Facades\Schema;public function boot() {Schema::defaultStringLength(191); } 

之后,一切都应该正常工作。

ps: 异常中明确指明最大长度是767字节,utf8mb4编码每字符使用4字节,所以 767 / 4 = 191.75,所以将string的默认长度设置为191字符即可。希望对大家有帮助

  相关解决方案