Eloquent:如何在使用create()方法时为保护列分配值?

时间:2016-04-17 15:35:00

标签: php mysql laravel eloquent laravel-5.2

假设我有一个用户提交表单的端点。表单输入将作为JSON对象存储在数据库表的列中,用户ID将存储在另一个中。因为我不希望用户能够以某种方式设置他们想要的任何用户ID,所以我将user_id列从Eloquent模型的$ fillable变量中删除。

create()方法接受要分配的键/值对数组,但只会将值分配给可填充列。如何同时将用户ID添加到受保护的user_id列?我是否必须获取最后一行并将用户ID更新为第二个操作?

感谢所有人的帮助,非常感谢。

2 个答案:

答案 0 :(得分:11)

如果您没有$fillable中的属性,那么这并不意味着您无法填写它。

$fillable属性包含可以使用create()fill()方法填充的属性,但您仍然可以使用属性访问权限为任何属性设置值。

因此,假设您拥有包含emailsomethingelse属性的模型。您可以像这样设置$fillable

protected $fillable = ['email', 'something'];

现在让我们假设你有这样的数据:

$data = [
  'email' => 'sample@example.com',
  'something' => 'foo',
  'else' => 'bar',
];

所以现在使用时:

Model::create($data);

您只会填写emailsomething因为$fillableelse不会被填充,因为它不是,但是你可以做这样的事情:

$model = new Model($data);
$model->else = 'bar';
$model->save();

因此您可以设置此else属性值,即使它不在$fillable内,但您需要像普通属性一样访问它。

答案 1 :(得分:-2)

虽然不完全是create()方法,但您可以使用forceCreate() - 在5.5中工作,即使它看起来没有记录。