解决 Syntax error or access violation: 1071 Specified key was too long; max key length is 1000 bytes

解决 Syntax error or access violation: 1071 Specified key was too long; max key length is 1000 bytes 报错。

这个错误信息是说,需要1071个字节,但是当前数据库最大长度是1000字节。

这里我们需要修改 app\Providers\AppServiceProvider.php 文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<?php

namespace App\Providers;

use Illuminate\Support\ServiceProvider;
use Illuminate\Support\Facades\Schema;

class AppServiceProvider extends ServiceProvider
{
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot()
{
// mb4string 1000/4=250
Schema::defaultStringLength(250);
}

/**
* Register any application services.
*
* @return void
*/
public function register()
{
//
}
}
  • boot 方法是所有应用执行前运行的方法;
  • Schema::defaultStringLength(250); 设置默认字符串长度为250
  • 在Laravel5.4之后默认的字符串使用类型是mb4string,一个长度为4个字节,这里用1000/4=250
坚持原创技术分享,您的支持将鼓励我继续创作!