Laravel 一般错误:1005 无法创建表

Posted

技术标签:

【中文标题】Laravel 一般错误:1005 无法创建表【英文标题】:Laravel General error: 1005 Can't create table 【发布时间】:2019-11-14 10:38:17 【问题描述】:

我在执行 php artisan 迁移时收到此错误。我的迁移文件有问题吗?

Illuminate\Database\QueryException : SQLSTATE[HY000]: 一般错误: 1005 无法创建表test.blog_posts (errno: 150 "外键 约束格式不正确”)(SQL:alter table blog_posts add 约束blog_pos ts_user_id_foreign外键(user_id) 参考users (id))

blog_posts

        $table->increments('id');
        $table->integer('cаtegory_id')->unsigned();
        $table->integer('user_id')->unsigned();
        $table->string('slug')->unique();
        $table->string('title');
        $table->text('excerpt')->nullable(); դաշտ չի
        $table->text('content_raw');
        $table->text('content_html');
        $table->boolean('is_published')->default(false);
        $table->timestamp('published_at')->nullable();
        $table->timestamps();
        $table->softDeletes(); 
        $table->foreign('user_id')->references('id')->on('users');
        $table->foreign('cаtegory_id')->references('id')->on('blog_categories');
        $table->index('is_published');

blog_categories

    $table->increments('id');
    $table->integer('parent_id')->unsigned()->default(0); 
    $table->string('slug')->unique();
    $table->string('title');
    $table->text('description')->unllable(); 
    $table->timestamps(); 
    $table->softDeletes();

用户

        $table->bigIncrements('id');
        $table->string('name');
        $table->string('email')->unique();
        $table->timestamp('email_verified_at')->nullable();
        $table->string('password');
        $table->rememberToken();
        $table->timestamps();

【问题讨论】:

【参考方案1】:

您需要将用户表中的列类型和格式匹配到 FK。但您首先需要在 blog_posts 表上实际创建列,从中绘制 FK 以完全匹配您在 users 表上的内容

$table->foreign('user_id')->references('id')->on('users');

是 FK 指令,但在此之前,您需要添加实际列以匹配用户表。 Nullable 是可选的,具体取决于您要如何进行:

$table->bigInteger('user_id')->unsigned()->nullable();

【讨论】:

以上是关于Laravel 一般错误:1005 无法创建表的主要内容,如果未能解决你的问题,请参考以下文章

如何解决 laravel 迁移错误“一般错误:1005 无法创建表”

“一般错误:1005 无法创建表”使用 Laravel 架构构建和外键

SQLSTATE[HY000]:一般错误:1005 无法创建表 Laravel 8

MySQL创建表:错误1005 errno:150“外键约束形成错误”

一般错误:1005 无法创建表

一般错误:1005 无法创建表 errno:150“外键约束格式不正确”)