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);

  • 相关阅读:
    C#读取并修改app.congig的实例
    apache:添加cgi模式
    初识golang
    Golang: pprof
    Golang:测试map是否存在
    beego: 获取request参数
    shell:crontab
    初识Iaas,paas
    初识golang
    Go-new和make
  • 原文地址:https://www.cnblogs.com/weiyalin/p/10385434.html
Copyright © 2011-2022 走看看