简体   繁体   English

具有一对一关系的 Laravel 批量插入

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM