如何在Eloquent数据透视表上设置额外字段的值

时间:2014-06-26 08:29:55

标签: laravel laravel-4 eloquent

$ recourse-> pivot-> field ='value';

给出错误:间接修改重载属性

3 个答案:

答案 0 :(得分:15)

pivot仅在关系的上下文中可用:

// won't work
$model = Model::first();
$model->pivot; // null

// will work
$anotherModel = AnotherModel::first();
$relatedModel = $anotherModel->relation()->first();
$relatedModel->pivot; // Pivot object

但是对于你想要做的事情,只需在save方法中使用额外的参数:

$product = Product::find($item->id);
$order->product()->save($product, ['price' => 12.34]);

对于现有关系:

$product = $order->product()->find($productId);
$product->pivot->price = 12.34;
$product->pivot->save();

// or
$order->product()->updateExistingPivot($productId, ['price'=>12.34]);

我建议您使用products来表示这种关系,以便于阅读。

答案 1 :(得分:0)

你应该保存()枢轴本身。

$order->pivot->price = '1.234';
$order->pivot->save();

答案 2 :(得分:0)

对于 Laravel 5,您可能需要使用以下语法:


$order->products()->attach($product, ['quantity' => 100]);

其中 quantity 是数据透视表的一个属性。