Laravel 上的“外键约束格式不正确”

Posted

技术标签:

【中文标题】Laravel 上的“外键约束格式不正确”【英文标题】:"Foreign key constraint is incorrectly formed" on Laravel 【发布时间】:2021-05-26 00:06:21 【问题描述】:

我正在尝试为我的数据库创建一个新表。 我之前创建了一个带有 PK (IdCorso) 的表 (tipo),然后创建了另一个带有与 Tipo 关联的外键的表 (corsoscii)。 当我为 corsoscii 执行 artisan 命令时 php artisan migrate --path='./database/migrations/2021_02_23_155544_create_corsoscii_table.php' 它给了我这个错误:

("SQLSTATE[HY000]: General error: 1005 Can't create table impianto_scii.corsoscii (errno: 150 "Foreign key constraint is incorrectly formed")")

这是“tipo”的设置代码

public function up()
    
        Schema::create('tipo', function (Blueprint $table) 
            $table->increments('idCorso');
            $table->string('descrizione');
            $table->timestamps();
        );
    

...对于“corsoscii”

  public function up()

    Schema::create('corsoscii', function (Blueprint $table) 
        $table->increments('idCorso');
        $table->integer('tipo');
        $table->string('nome');
        $table->integer('membriMax');
        $table->date('inizio');
        $table->date('fine');
        $table->timestamps();

    );

    Schema::table('corsoscii', function(Blueprint $table)

        $table->foreign('tipo')
            ->references('idCorso')->on('tipo')
            ->onDelete('cascade');
        
        $table->primary('idCorso');
    );

我是 Laravel 的新手,欢迎任何建议。

【问题讨论】:

我认为$table->integer('tipo');应该是$table->integer('tipo')->unsigned();来匹配相同的数据类型 “它不起作用”不是很准确,总是返回相同的错误?这是你的数据库引擎 InnoDB? 出现同样的错误。是的,我的数据库引擎是 InnoDB 【参考方案1】:

$table->integer('tipo'); 需要完全匹配它作为外键的字段。

$table->increments('idCorso'); 生成一个unsignedInteger,所以它应该是这样的。

$table->unsignedInteger('tipo');

如果您的迁移使用bigIncrements,则需要使用:

$table->unsignedBigInteger('tipo');

【讨论】:

@porloscerrosΨ 你说得对,我很抱歉。 Laravel 现在默认使用 bigIncrements 创建新的迁移,因此我很困惑。更新了答案。【参考方案2】:

请先运行

php artisan migrate:rollback

然后删除“corsoscii”表。然后尝试这些更改。

Schema::create('corsoscii', function (Blueprint $table) 
            $table->increments('idCorso');
            $table->integer('tipo')->unsigned();;
            $table->string('nome');
            $table->integer('membriMax');
            $table->date('inizio');
            $table->date('fine');
            $table->timestamps();

        );

        Schema::table('corsoscii', function(Blueprint $table)

            $table->foreign('tipo')
                  ->references('idCorso')->on('tipo')
                  ->onDelete('cascade');
        );

首先尝试 unsigned() 为tipo,然后idCorso 已经是主键,当你将使用increments() 方法时。然后运行

php artisan migrate

这会很好。我试过了。

【讨论】:

以上是关于Laravel 上的“外键约束格式不正确”的主要内容,如果未能解决你的问题,请参考以下文章

Laravel 迁移错误:150“外键约束格式不正确”

laravel errno 150 外键约束格式不正确

Laravel 迁移:Errcode:150“外键约束格式不正确”

laravel 5.4 迁移错误:150“外键约束格式不正确”

Laravel 外键约束格式不正确我已经搜索过,找不到答案

Laravel 迁移:“外键约束格式不正确”(errno 150)