位置: 编程技术 - 正文

Laravel 5.4中migrate报错: Specified key was too long error的解决

编辑:rootadmin

推荐整理分享Laravel 5.4中migrate报错: Specified key was too long error的解决,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

大家都知道,我们经常做项目都团队协作开发,每个人都在自己本地的数据库,如果你曾经出现过让同事手动在数据库结构中添加字段的情况,数据库迁移可以解决你这个问题。

不仅如此,在线上部署的时候,也避免了手动导入数据库或手动修改数据结构的麻烦,数据迁移帮你方便的维护着数据结构。

但方便的同时也会伴随着一些问题,下面这篇文章将详细给大家介绍关于Laravel5.4中migrate报错Specified key was too long error的解决方法,下面话不多说了,来一起看看详细的介绍吧。

Laravel 5.4中migrate报错: Specified key was too long error的解决

发现问题

Laravel 5.4默认使用utf8mb4字符编码,而不是之前的utf8编码。因此运行php artisan migrate 会出现如下错误:

问题根源

MySql支持的utf8编码最大字符长度为3字节,如果遇到4字节的宽字符就会出现插入异常。三个字节UTF-8最大能编码的Unicode字符是0xffff,即Unicode中的基本多文种平面(BMP)。因而包括Emoji表情(Emoji是一种特殊的Unicode编码)在内的非基本多文种平面的Unicode字符都无法使用MySql的utf8字符集存储。

这也应该就是Laravel 5.4改用4字节长度的utf8mb4字符编码的原因之一。不过要注意的是,只有MySql 5.5.3版本以后才开始支持utf8mb4字符编码(查看版本:selection version();)。如果MySql版本过低,需要进行版本更新。

注:如果是从Laravel 5.3升级到Laravel 5.4,不需要对字符编码做切换。

解决问题

升级MySql版本到5.5.3以上。 手动配置迁移命令migrate生成的默认字符串长度,在AppServiceProvider中调用Schema::defaultStringLength方法来实现配置:

总结

标签: Laravel 5.4中migrate报错: Specified key was too long error的解决

本文链接地址:https://www.jiuchutong.com/biancheng/274983.html 转载请保留说明!

上一篇:PHP实现保存网站用户密码到css文件(通用型)(php实现保存网站内容)

下一篇:Linux平台中使用PHP把word转pdf的实现方法(linux如何使用)

  • 小规模免增值税是普票还是专票
  • 代扣代缴增值税是什么意思
  • 应交税费科目的借贷方向
  • 赠送货物怎么入账
  • 房屋租赁个人所得税缴纳标准是多少
  • 固定资产采购计入什么科目
  • 酒店代金券怎么做账
  • 季度所得税申报表营业收入怎么填
  • 财税〔2017〕39号
  • 税收协助
  • 业务招揽方式
  • 关于发票入账的会计分录
  • 未达起征点怎么写摘要
  • 债转股的税收政策
  • 2021年如何申报海外收入
  • 未确认融资费用的期初余额
  • 装饰公司发票怎么
  • 鸿蒙壁纸怎么设置滚动
  • 用户登录系统后首先进入什么
  • window10拖动窗口的手势
  • 中途建账科目余额表怎么建
  • 票据的追索权与再追索权
  • kwservice.exe是什么
  • PHP:session_regenerate_id()的用法_Session函数
  • 外资企业采购退税流程
  • 投资性房地产期末公允价值大于账面价值
  • u盘格式化技巧
  • php生成php文件
  • 【2023-Pytorch-检测教程】手把手教你使用YOLOV5做电线绝缘子缺陷检测
  • Chrome谷歌浏览器官网
  • php中.的作用
  • 利润表利息费用怎么填
  • 可解释深度学习:从感受野到深度学习的三大基本任务:图像分类,语义分割,目标检测,让你真正理解深度学习
  • vue事件bus
  • PHP中set_include_path()函数相关用法分析
  • 转账支票适用范围
  • 注册公司填写从业人数多少合适
  • 一般纳税人销售自行开发的软件产品
  • sql server附加数据库出错
  • mongodb中主键的默认格式是哪个?
  • 普通发票该可以抵扣吗
  • mongodb安装教程win10
  • 处理固定资产如何做账
  • 物业公司物业费计入什么会计科目
  • pycharm怎么安装mysql
  • 小规模纳税人减按1%如何填报申报表
  • 建筑企业如何按季度申报
  • 收到政府的资本公积可以投入子公司吗
  • 预存话费发票能报销吗
  • 债务人对债权人享有
  • 公司基本户的钱怎么用
  • 赠品不开票怎么办
  • mysql分页实现
  • windows硬盘是什么意思
  • vi修改文件
  • ubuntu20.04常用软件
  • linux系统故障及解决方法
  • rhel6安装
  • 微软今天正式停产了吗
  • win10自带地图打不开
  • win10组策略编辑器没有
  • Linux系统中如何编译C程序?
  • js导出excel文件前端插件
  • Unity3D游戏开发标准教程吴亚峰于复兴人民邮电出版社
  • Unity3D游戏开发基础
  • 详解16型人格
  • Node.js中的全局变量有哪些
  • fragment的context
  • js控制鼠标位置
  • node.js怎么样
  • python strip函数作用
  • actionscript与javascript的区别
  • 安卓底层重写
  • 图片旋转鼠标键盘怎么弄
  • java项目怎么变成web项目
  • js面向对象的三大特性
  • jqgrid loadcomplete
  • 捐赠纳税
  • 知道金额,税额怎么计算
  • 国税总局编制这次怎么调整
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设