zoukankan      html  css  js  c++  java
  • laravel5.7 migrate 时报错 Specified key was too long error 解决方案

    今天在数据迁移时突然报了 Specified key was too long error 的错,解决掉之后就把这个问题记录下来。

    报错原因

    Laravel 5.4 +  默认使用 utf8mb4 字符编码,之前使用的是 utf8 编码

    我mysql数据库使用的是 utf8 编码,支持的最大字符长度为3字节,如果遇到4字节的宽字符就会出现插入异常。

    注意:三个字节 utf8 最大能编码的 Unicode 字符是 0xffff ,即Unicode中的基本多文种平面(BMP)。因而包括Emoji表情(Emoji是一种特殊的Unicode编码)在内的非基本多文种平面的Unicode字符都无法使用 MySql 的 utf8 字符集存储。

     解决方案:

    1. 升级MySql版本到5.5.3+ ,因为从MySql 5.5.3 开始才支持 utf8mb4 字符编码。将字符编码设置为utf8mb4。
    2. 手动配置迁移命令 migrate 生成的默认字符串长度,在 AppServiceProviderboot 方法中添加如下代码:
    Schema::defaultStringLength(191);

  • 相关阅读:
    串口调试助手
    自己动手编写俄罗斯方块
    ASP.NET Core log4net
    ASP.NET Core读取配置文件
    ASP.NETCore3 MVC
    ASP.NETCore2C#7.0新语法
    ASP.NETCore1C#6.0新语法
    C#加密解密
    前端通用的滚动条样式
    C# 106 短信发送
  • 原文地址:https://www.cnblogs.com/weiyalin/p/10385434.html
Copyright © 2011-2022 走看看