Laravel 5.4因特殊字段太长导致migrations报错的解决

 更新时间:2017年10月22日 08:36:44   作者:随风  
这篇文章主要给大家介绍了关于Laravel 5.4因特殊字段太长导致migrations报错的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧。

前言

本文主要介绍了关于Laravel 5.4因特殊字段太长导致migrations报错的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:

laravel 5.4 改变了默认的数据库字符集,现在utf8mb4包括存储emojis支持。MySQL 需要v5.7.7或者更高版本,当你试着在一些MariaDB或者一些老版本的的MySQL上运行 migrations 命令时,你会碰到下面这个错误:

 [Illuminate\Database\QueryException]
 SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes (SQL: alter table `users` add unique `use
 rs_email_unique`(`email`))
 
 [PDOException]
 SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes

解决方法

经过查询,我们可以在 AppServiceProvider.php 文件里的 boot 方法里设置一个默认值:

<?php
namespace App\Providers;
 
use Illuminate\Support\ServiceProvider;
//添加的代码
use Illuminate\Support\Facades\Schema;
 
class AppServiceProvider extends ServiceProvider
{
 /**
  * Bootstrap any application services.
  *
  * @return void
  */
 public function boot()
 {
  //添加的代码
  Schema::defaultStringLength(191);
 }
 
 /**
  * Register any application services.
  *
  * @return void
  */
 public function register()
 {
  //
 }
}

总结

以上就是这篇文章的全部内容了,本文还有许多不足,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • Laravel框架在本地虚拟机快速安装的方法详解

    Laravel框架在本地虚拟机快速安装的方法详解

    这篇文章主要介绍了Laravel框架在本地虚拟机快速安装的方法,结合实例形式较为详细的分析了Laravel框架的安装步骤、操作注意事项,并附带说明了centos7环境下php7编译安装curl扩展的具体操作步骤,需要的朋友可以参考下
    2018-06-06
  • ThinkPHP实现事务回滚示例代码

    ThinkPHP实现事务回滚示例代码

    这篇文章主要介绍了ThinkPHP实现事务回滚,需要的朋友可以参考下
    2014-06-06
  • Laravel中获取路由参数Route Parameters的五种方法示例

    Laravel中获取路由参数Route Parameters的五种方法示例

    这篇文章主要给大家介绍了关于Laravel中获取路由参数Route Parameters的五种方法,文中通过示例代码介绍的非常详细,对大家学习或者使用Laravel具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-09-09
  • Laravel中的Blade模板引擎示例详解

    Laravel中的Blade模板引擎示例详解

    laravel的模版引擎采用了blade模版引擎,下面这篇文章主要给大家介绍了关于Laravel中Blade模板引擎的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-10-10
  • php pthreads多线程的安装与使用

    php pthreads多线程的安装与使用

    这篇文章主要介绍了php pthreads多线程的安装与使用 的相关资料,需要的朋友可以参考下
    2016-01-01
  • PHP面向对象之领域模型+数据映射器实例(分析)

    PHP面向对象之领域模型+数据映射器实例(分析)

    下面小编就为大家带来一篇PHP面向对象之领域模型+数据映射器实例(分析)。小编觉得挺不错的。现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • CodeIgniter记录错误日志的方法全面总结

    CodeIgniter记录错误日志的方法全面总结

    这篇文章主要介绍了CodeIgniter记录错误日志的方法,详细分析了CodeIgniter框架的文件结构与相应的功能,结合实例分析了CodeIgniter框架记录错误日志的实现技巧,并分析了隐藏index文件与数据传输等技巧,总结非常全面,需要的朋友可以参考下
    2016-05-05
  • 关于laravel 日志写入失败问题汇总

    关于laravel 日志写入失败问题汇总

    今天小编就为大家分享一篇关于laravel 日志写入失败问题汇总,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • thinkPHP中验证码的简单使用方法

    thinkPHP中验证码的简单使用方法

    这篇文章主要介绍了thinkPHP中验证码的简单使用方法,涉及thinkPHP验证码逻辑功能的实现与界面显示的相关技巧,需要的朋友可以参考下
    2015-12-12
  • codeigniter显示所有脚本执行时间的方法

    codeigniter显示所有脚本执行时间的方法

    这篇文章主要介绍了codeigniter显示所有脚本执行时间的方法,涉及codeigniter中elapsed_time方法与{ elapsed_time}伪变量的使用技巧,需要的朋友可以参考下
    2015-03-03

最新评论