位置: 编程技术 - 正文

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如何使用)

  • 购买土地缴纳的费用
  • 关税的计算公式是什么
  • 国家重大水利工程建设基金计算方法
  • 其他应收款怎样做平
  • 无形资产减值损失一经确认在以后期间不得转回
  • 票面3个点什么意思
  • 不动产折旧年限的规定
  • 金税盘处于报税期是什么意思
  • 企业间借款利息怎么算
  • 学校收到政府拨付的助学金和奖学金需要缴纳税款吗
  • 写字楼出租可以给租户注册吗
  • 分配利润和分配股利
  • 公司还没有核税该如何进行业务汇款?
  • 新建账套应收账款怎么填客户
  • 特许权使用费预扣预缴计算方法
  • 增值税发票清单怎么导出
  • 小规模纳税人增值税优惠政策
  • 一般纳税人出租不动产增值税税率
  • 租车服务的税率
  • 关税完税价格包含关税吗
  • 应收票据借方表示负债吗
  • 什么是税收编码,在哪里查
  • 公司发手机奖励合法吗
  • 发票的校验码被公章覆盖了怎么办
  • 小规模纳税人0税率
  • 注销企业很麻烦
  • 销售货物没有合同要交印花税吗
  • 客户汇公司账户怎么汇
  • 不良品退回处理流程
  • 福利费用会计分录
  • 免税出口样品收多少税
  • 鸿蒙系统怎么快速充电
  • 东方蝾螈怎么养吃什么
  • 鸿蒙系统蓝牙耳机声音小怎么办
  • 引入人工智能
  • 多目标pso
  • 小型企业资产负债表
  • php的mysql_query
  • typescript instanceof
  • 猿类作文
  • 购买完服务器之后要怎么做
  • 研发人员工资计入什么科目
  • iotop命令 监视磁盘I/O状态
  • 下脚料收入计入什么科目
  • 文章列表是什么
  • 公办学校的会计
  • 增值税买一送一处理方法
  • 微信平台的收入从哪里来
  • 百旺金赋服务费不交会怎么样?
  • 增值税发票丢失可以重开吗
  • 资产减值损失的借贷方向
  • 基本户是活期还是定期
  • 收到退回的企业所得税分录
  • 企业招聘残疾人税收优惠
  • 企业开办期间账务处理
  • 消费税和购置税系重复征税
  • 库存现金银行存款用什么凭证
  • 当月的进项税可以不认证吗?
  • 技术转让费如何计算
  • 员工报销固定资产怎么算
  • 应收账款应付账款借贷方都表示什么
  • 在建工程的消防要求
  • 贷款利息支出属于财务费用吗
  • 劳务费免税发票怎么开
  • 会计科目设置的相关注意事项
  • mysql调用java
  • mysql数据库-数据库和表的基本操作
  • mysql数据库的介绍
  • thinkpad如何安装win10
  • app隐藏库
  • winxp无法删除文件
  • windows7装进u盘
  • 如何开启金山毒霸
  • javascript的代码写在哪里
  • Shell脚本监控日志 出现关键字 grep提醒
  • 详解 linux mysqldump 导出数据库、数据、表结构
  • ubuntu on android
  • linux shell脚本命令
  • 普通发票冲红怎么报税
  • 发票机怎么测试打印
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设