问题描述
(1)laravel 5.4或者更高版本 改变了默认的数据库字符集,现在utf8mb4包括存储emojis支持。如果你运行MySQL v5.7.7或者更高版本,则不需要做任何事情。
(2)当你试着在一些MariaDB或者一些老版本的的 MySQL 上运行 migrations 命令时,你可能会碰到下面这个错误:
Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes
【指定的键太长了,最大键的长是767bytes,因为 laravel 默认字符串长度是767bytes,所以要自己去手动配置。】
解决方案
<?php namespace App\Providers; // 导入Schema类 use Illuminate\Support\Facades\Schema; use Illuminate\Support\ServiceProvider; class AppServiceProvider extends ServiceProvider { public function boot() { // 在app/providers/AppServiceProvider.php中boot方法中加上 Schema::defaultStringLength(191); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 银行核心海量数据无损迁移:TDSQL数据库多源异构迁移方案
- 简单数据库迁移实践
- 再无需从头训练迁移学习模型!亚马逊开源迁移学习数据库 Xfer
- flask 迁移数据库工具
- redis数据库迁移方案
- 用 Golang 处理数据库迁移
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。