当前位置:   article > 正文

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 l

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方法内设置默认字符串长度:

  1. use Illuminate\Support\Facades\Schema;
  2. public function boot()
  3. {
  4. //
  5. Schema::defaultStringLength(191);
  6. }

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

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

 

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号