尝试分配外键,但是当您运行迁移时,我收到此错误,我不明白问题是什么。
SQLSTATE[HY000]:一般错误:1215 无法添加外键约束(SQL:alter tablecategories
添加约束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');
我有同样的问题。
当模型与其自身存在关系(自关系)时,就会出现问题。
要解决这个问题,首先必须创建迁移文件,然后必须在另一个迁移文件中分配外键。
您必须从迁移文件中删除外键分配,然后创建新的迁移文件,然后添加关系语句来分配外键。 (迁移文件的顺序很重要)。
创建类别表
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();
}
创建类别关系表
public function up(): void
{
$table->foreign('parent_key')->references('key')
->on((new Category())->getConnection()->getDatabaseName() . '.' . Category::TABLE)
->onDelete('cascade');
}
进而php artisan migration
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)