[英]Laravel bulk insert with one-to-one relation
I know that I can insert multiple records in laravel with:我知道我可以在 laravel 中插入多条记录:
$data = [
['name' => '...', 'age' => ...],
['name' => '...', 'age' => ...],
['name' => '...', 'age' => ...],
];
Model::insert($data);
But is is possible to do a bulk insert that also has a one-to-one relation?但是是否可以执行也具有一对一关系的批量插入? So that I insert data into two databases at the same time?
这样我就可以同时将数据插入到两个数据库中?
Something like:类似的东西:
$data = [ ['name' => '...', 'age' => ...], ['name' => '...', 'age' => ...], ['name' => '...', 'age' => ...], ]; $data = [ ['name' => '...', 'age' => ...], ['name' => '...', 'age' => ...], ['名称' => '...', '年龄' => ...], ];
Model::withSecondTable()->insert($data);
Yes it is possible.是的,这是可能的。 For example:
例如:
###User Model: ###用户模型:
public function item()
{
return $this->belongsTo('Item');
}
###Item Model: ###物品型号:
public function users()
{
return $this->hasMany('User');
}
To save a User from the Item perspective, you do this:要从项目角度保存用户,您可以执行以下操作:
$item->users()->save($user);
To associate an item with a user, you do this:要将项目与用户关联,请执行以下操作:
$user->item()->associate($item);
$user->save();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.