多表写入数据如何实现?
当前有表A和表B,A和B是关联的。
表A有id, name, password等字段,表B有pid,tag,status等字段。
表A的id和表B的pid相互关联。
请教在表A插入一条数据的时候,表B也能插入一条数据?
经过摸索,自己解决了。
$user = [
'name' => '123456',
'password' => Hash::make($request->post('password')),
];
$data = AModel::create($user); // 根据信息插入一条数据
$findA = AModel::find($data['id']); // 根据id查找A表数据
$BData = $findUser->BDataModel()->create(); // 根据找到的数据,插入B表(pid自动创建 = A表id)
printf($BData); // 正常打印结果
这个就需要自己写喽
可以使用模型的事件系统做,保存成功后会自动触发
saved
事件,然后监听这个事件,对 B 表做新增即可。详细可以查看 Eloquent 事件 章节。
@24K大白羊 createMany 方法去创建多个关联模型不知道能不能实现?
associate