Laravel - 将列添加到现有数据透视表 table 并添加 MUL 键

Laravel - Add column to existing pivot table and add MUL key

我有一个 Laravel 枢轴 table,其中包含多个主键:"order_id"、"product_id"、"variation_id".

我需要向这个 table 添加一个名为 "id" 的新列,我的操作如下:

public function up()
    {
        Schema::table('order_product', function (Blueprint $table) 
        {
            $table->integer('id')->unsigned()->after('variation_sku');
        });
    }

我的原始迁移文件如下所示:

public function up()
    {
        Schema::create('order_product', function (Blueprint $table) 
        {
            $table->integer('order_id')->unsigned()->index();
            $table->foreign('order_id')->references('order_id')->on('orders')->onDelete('cascade');
            $table->integer('product_id')->unsigned()->index();
            $table->foreign('product_id')->references('product_id')->on('products')->onDelete('cascade');
            $table->integer('variation_id')->unsigned()->index()->nullable();
            $table->jsonb('variation')->nullable();
            $table->integer('qty');
            $table->string('variation_status')->default('bakery');
            $table->timestamps();
            $table->softDeletes();
            $table->primary(['order_id', 'product_id', 'variation_id']);
        });
    }

此迁移包括我的 3 个复合键。

我现在需要添加新列 "id" 并将此列添加到复合键。

我在 Laravel 文档中找不到任何内容,并且怀疑这不可能,因为它可能会影响此 table 中过去的记录。

您可以删除主键然后创建一个新主键:

public function up()
{
    Schema::table('order_product', function (Blueprint $table) 
    {
        $table->integer('id')->unsigned()->after('variation_sku');
        $table->dropPrimary();
        $table->primary(['id', 'order_id', 'product_id', 'variation_id']);
    });
}