Laravel 5.4 如何更新数据透视表?

Posted

技术标签:

【中文标题】Laravel 5.4 如何更新数据透视表?【英文标题】:Laravel 5.4 How to update pivot table? 【发布时间】:2018-02-26 17:25:13 【问题描述】:

我有下一个结构数据透视表:products_equipment_value(id, product_id, equipment_id, value_id)。如何更新表字段 equipment_id 和 value_id ?

 public function equipments()
    
        return $this->belongsToMany('App\Equipment', ' product_equipment_value');
    

    public function values()
    
        return $this->belongsToMany('App\Value', ' product_equipment_value', 'product_id', 'value_id')
    

使用(不工作)

 $product->equipments()->detach();
       foreach($data['eq'] as $key => $val)
         $product->equipments()->attach([
           'equipment_id' =>  $key,
            'value_id' =>$val
          ]);
      

【问题讨论】:

【参考方案1】:

参考多对多 Eloquent 的关系 (https://laravel.com/docs/5.5/eloquent-relationships#many-to-many) 你可以像这样同步 ID:

$product->equipments()->sync([array_of_equipments_ids]);

例子:

$product->equipments()->sync([3, 8, 9, 24]);

如果您定义了多对多反向关系,您也可以从设备实例中这样做:

$equipment->values()->sync([array_of_values_ids]);

如果您的数据透视表有额外的列,您可以像这样添加它们:

public function equipments()
    return $this->belongsToMany('App\Equipment', 'product_equipment_value')->withPivot('extra_column1');

等等:

$product->equipments()->sync([1 => ['extra_column1' => 'Value for this column']])

请注意,您可以使用 sync() 或 attach() 方法来构建多对多关联。你可以看这里:https://***.com/a/23969879/8620746

【讨论】:

【参考方案2】:

你应该在关系上使用withPivot函数。

public function equipments()

    return $this->belongsToMany('App\Equipment', 'product_equipment_value')->withPivot('value_id');

然后当你附加模型时

$product->equipments()
    ->attach([
        $key => ['value_id' =>$val],            
    ]);

【讨论】:

以及如何推导出Product(简单方法)|product.title|equipment.title|value.title| 当你调用 $product->equipments 将返回一个设备集合,如果你只想要第一个使用 first() 方法($product->equipments->first()->title)跨度>

以上是关于Laravel 5.4 如何更新数据透视表?的主要内容,如果未能解决你的问题,请参考以下文章

Excle数据透透视表如何删除数据透视表

如何在 laravel 5 中使用 Eloquent 更新数据透视表

laravel:更新或创建(更新插入)数据透视表

Laravel 复选框问题,我无法更新数据透视表

laravel4 更新数据透视表中的附加列

在多对多关系 laravel4 的情况下更新数据透视表