Laravel:无法添加外键约束

问题描述 投票:1回答:1

我想将一个外键从order_product_table上的'order_id'添加到order_table上的'id'。

我无法迁移这两个表,但出现错误:

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()

感谢您的帮助。

database laravel join foreign-keys migrate
1个回答
0
投票

尝试更改:$ table-> increments('id');到$ table-> bigIncrements('id')

© www.soinside.com 2019 - 2024. All rights reserved.