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 uniqueusers_email_unique
([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字符即可。希望对大家有帮助)