gpt4 book ai didi

mysql - Laravel 迁移无法添加外键

转载 作者:IT老高 更新时间:2023-10-28 23:58:56 28 4
gpt4 key购买 nike

我正在尝试编写一个 laravel 数据库迁移,但我收到以下关于外键的错误:

  [Illuminate\Database\QueryException]                                                                                                                                                                                                                    
SQLSTATE[42000]: Syntax error or access violation: 1072 Key column 'category_id' doesn't exist in table (SQL: alter table `subcategories` add constraint subcategories_category_id_foreign foreign key (`category_id`) references `categories` (`id`))



[PDOException]
SQLSTATE[42000]: Syntax error or access violation: 1072 Key column 'category_id' doesn't exist in table

确实会创建 categoriessubcategories 表,但不会创建外键。这是我的迁移:

<?php

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateCategoryTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('categories', function ($table) {
$table->increments('id')->unsigned();
$table->string('name')->unique();
});

Schema::create('subcategories', function ($table) {
$table->increments('id')->unsigned();
$table->foreign('category_id')->references('id')->on('categories');
$table->string('name')->unique();
});
}

/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::drop('categories');
Schema::drop('subcategories');
}
}

有什么想法吗?谢谢!

最佳答案

您应该在创建外键之前创建列:

$table->integer('category_id')->unsigned();
$table->foreign('category_id')->references('id')->on('categories');

文档:http://laravel.com/docs/5.1/migrations#foreign-key-constraints

关于mysql - Laravel 迁移无法添加外键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33633684/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com