laravel 执行migrate出现异常


今天在执行laravel migrate时出现异常,找了好半天才找到问题所在,特此记录一下。

配好数据库,执行 ``` php artisan migrate ```。但是遇到了问题:

migrations中up函数为:

public function up()

{

Schema::create(‘users‘, function (Blueprint $table) {

$table->increments(‘id‘);

$table->string(‘name‘);

$table->string(‘email‘)->unique();

$table->string(‘password‘);

$table->rememberToken();

$table->timestamps();

});

}

执行

E:\work\www\blog>php artisan migrate

出现异常:

Migration table created successfully.

[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 `users_email_unique`(`email`))

[PDOException]

SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes

网上也没查不明所以,在 stackoverflow上有人说跟数据库引擎有关(InnoDB 的 key 支持 767 字节,而 MyISAM 支持 1000 字节。) (http://stackoverflow.com/questions/1814532/1071-specified-key-was-too-long-max-key-length-is-767-bytes)。

但是我尝试了 MyISAM 仍然报同样错误,只是 767 变为了 1000。

后来我在数据库配置文件发现了端倪 ```config/database.php``` (laravel版本为5.4):

老的 5.3

```php

‘mysql‘ => [

‘driver‘ => ‘mysql‘,

‘host‘ => env(‘DB_HOST‘, ‘localhost‘),

‘port‘ => env(‘DB_PORT‘, ‘3306‘),

‘database‘ => env(‘DB_DATABASE‘, ‘forge‘),

‘username‘ => env(‘DB_USERNAME‘, ‘forge‘),

‘password‘ => env(‘DB_PASSWORD‘, ‘‘),

‘charset‘ => ‘utf8‘,

‘collation‘ => ‘utf8_unicode_ci‘,

‘prefix‘ => ‘‘,

‘strict‘ => true,

‘engine‘ => null,

],

```

新的 5.4

```php

‘mysql‘ => [

‘driver‘ => ‘mysql‘,

‘host‘ => env(‘DB_HOST‘, ‘127.0.0.1‘),

‘port‘ => env(‘DB_PORT‘, ‘3306‘),

‘database‘ => env(‘DB_DATABASE‘, ‘forge‘),

‘username‘ => env(‘DB_USERNAME‘, ‘forge‘),

‘password‘ => env(‘DB_PASSWORD‘, ‘‘),

‘charset‘ => ‘utf8mb4‘,

‘collation‘ => ‘utf8mb4_unicode_ci‘,

‘prefix‘ => ‘‘,

‘strict‘ => true,

‘engine‘ => null,

],

```

发现没 laravel 5.4 开始使用 utf8mb4 数据库字符集了。这个字符集在 MySQL 5.5.3 开始支持。

[utf8 和 utf8mb4 区别看这里](http://ourmysql.com/archives/1402)

如是将 ``` config/database.php ``` 改为

```

‘charset‘ => ‘utf8‘,

‘collation‘ => ‘utf8_unicode_ci‘,

```

重新执行``` php artisan migrate ```,success!

时间: 2024-11-11 20:21:55

laravel 执行migrate出现异常的相关文章

hive 执行sql客户端异常

FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask. java.lang.RuntimeException: Unable to instantiate org.apache.hadoop.hive.metastore.HiveMetaStoreClient 未启动hive元数据仓库 : hive --service metastore hive 执行sql客户端异常

通过DeveloperApi获取spark程序执行进度及异常

效果显示: 代码: package org.apache.spark.zpc.listener import org.apache.spark.Logging import org.apache.spark.scheduler._ import scala.collection.mutable /** * Spark 的 DeveloperApi 提供针对app, job, task的执行监听. * 通过该监听,可以实现: * 1.任务执行进度的粗略计算. * 2.执行异常失败时,获取异常信息.

解决点击关闭按钮,应用程序退出时,系统爆出“集合已修改,可能无法执行枚举操作”异常的相关思路

这两天在优化升级公司的一个业务系统时,更改了一下窗体关闭事件中的一句代码,由system.Enviromen.Exit(0)改为了Application.Exit();但是这时候问题就出现了,当点击系统右上角关闭按钮的时候,会爆出“集合已修改,可能无法执行枚举操作”的异常.如下图所示: 这是什么原因造成的呢?问了一下度娘,出现“集合已修改,可能无法执行枚举操作”这种异常大部分都是因为误用foreach语句引起的,foreach是取只读的,在取的时候数据不能变(包括修改,删除,添加等).要避免这个

Laravel 5 migrate时报错: Specified key was too long error

Laravel 5.4默认使用utf8mb4字符编码,而不是之前的utf8编码.因此运行php artisan migrate 会出现如下错误: [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

记Android R(SDK=30)系统执行UiAutomator1.0异常

最近Android发布了AndroidStudio 3.6稳定版,升级后明显能体验到好多细节的提升,最大的提升莫过于可以创建Android R预览版的模拟器了,并且模拟器可以设置多个尺寸的屏幕.Android R的xm6模拟器可以直接运行arm架构的程序,以后开发过程中再也不用为测试机担忧了.但是在执行UiAutomator1脚本时就存在了不兼容问题. 异常情况 但是在使用Android R模拟器进行开发工作中发现执行UiAutomator1.0脚本出现如下异常: Warning: This v

执行sql语句异常...需要的参数与提供的值个数不匹配

执行mysql语句时,出现以下错误时. 看错误提示,提示说你的sql语句只需要5个参数,而你提供了8个值value,你确定你确实需要8个参数,而你的sql语句却提示说只需要5个参数 这时,请仔细检查一下你的sql语句 发现没有,在更新语句update的  a.product_image_url='?   这里多加了一个単引号,导致后面的3个参数没有被找到 这里只需把単引号去掉

laravel中的HTTP异常和日志

HTTP异常 App::abort('404','Page not found'); App::abort('401','You are not authorized'); App::missing(function($exception){ return Response::view('errors.missing',array(),404); }); 7个日志级别debug.info.notice.warning.error.critical.alert // Log::info('This

MongoDB 执行mongoexport时异常及分析

今天在用mongoexport导出满足一定条件下的数据时,遇到了一个报错,现纪录下来,并且针对此错误对MongoDB 的?数字类型?做了进一步的学习. 背景及报错信息?今天接到一个业务需求,需要从MongoDB 数据库 order集合中导出符合以下条件的数据: db.qqwj_order.find({"Source":NumberInt("21"),"Batch":"支付中的订单提醒:2018/9/5","MsgCo

spring boot 项目使用idea正常打包后执行总是出现异常,解决办法

众所周知,spring boot 在构建项目时,确实为Java程序员们省了不少力气,打包项目非常容易. 上周在项目中遇到打包后的项目总是无法运行,困扰了我们团队将近两天才找到原因. 图和真相在这里. 原文地址:https://www.cnblogs.com/nulijiushimeili/p/11029452.html