Laravel: невозможно добавить ограничение внешнего ключа - PullRequest
2 голосов
/ 26 мая 2020

Я хочу добавить внешний ключ от 'order_id' в таблице order_product_table к 'id' в таблице order_table.

Я не могу перенести эти две таблицы, я получаю сообщение об ошибке:

General error: 1215 Cannot add foreign key constraint (SQL: alter table `order_products` add constraint `order_products_order_id_foreign` foreign key (`order_id`) references `orders` (`id`) on delete set null on update cascade)

2020_05_14_135759_create_orders_table

        Schema::create('orders', function (Blueprint $table) {
            $table->increments('id');

            $table->integer('user_id')->unsigned()->nullable();
            $table->foreign('user_id')->references('id')->on('users')->onUpdate('cascade')->onDelete('set null');

            $table->string('billing_email');
            $table->string('billing_name');
            $table->string('billing_address');
            $table->string('billing_city');
            $table->string('billing_postalcode');
            $table->string('billing_phone');
            $table->string('billing_name_on_card');
            $table->integer('billing_total');
            $table->timestamps();
        });

2020_05_14_142218_create_order_products_table

Schema::create('order_products', function (Blueprint $table) {
            $table->increments('id');

            $table->integer('order_id')->unsigned()->nullable();
            $table->foreign('order_id')->references('id')->on('orders')->onUpdate('cascade')->onDelete('set null');

            $table->integer('product_id')->unsigned()->nullable();
            $table->integer('quantity')->unsigned();
            $table->timestamps()

Спасибо за вашу помощь.

1 Ответ

0 голосов
/ 26 мая 2020

попробуйте изменить: $ table-> increments ('id'); в $ table-> bigIncrements ('id')

...