SQLSTATE[HY000]:一般错误:1215无法添加外键约束laravel 9



试图分配外键,但当你运行migrate时,我得到了这个错误,我不明白问题是什么。

SQLSTATE[HY000]:一般错误:1215无法添加外键约束(SQL:更改表categories添加约束categories_parent_key_foreign外键(parent_key(引用删除级联上的categories(key((

$table->bigIncrements('id');
$table->string('key', 64)->unique();
$table->string('parent_key', 64)->nullable()->index();
$table->string('title', 256)->index()->unique();
$table->foreign('parent_key')->references('key')
->on((new Category())->getConnection()->getDatabaseName() . '.' . Category::TABLE)
->onDelete('cascade');

我也遇到了同样的问题。当一个模型与自身存在关系(自关系(时,问题就出现了。要解决此问题,首先必须创建迁移文件,然后必须在另一个迁移文件中分配外键。您必须从迁移文件中删除外键分配,然后创建新的迁移文件,然后添加关系语句来分配外键。(迁移文件的顺序很重要(。

create_category_table

public function up(): void
{
$table->bigIncrements('id');
$table->string('key', 64)->unique();
$table->string('parent_key', 64)->nullable()->index();
$table->string('title', 256)->index()->unique();
}

create_category_relation_table

public function up(): void
{
$table->foreign('parent_key')->references('key')
->on((new Category())->getConnection()->getDatabaseName() . '.' . Category::TABLE)
->onDelete('cascade');
}

然后php artisan migration

在我的案例中,问题在于被引用的表键和键引用的不同数据类型。例如,integer(unsigned(bigInteger(unssigned(

最新更新