多表写入数据如何实现?

当前有表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); // 正常打印结果
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 3

这个就需要自己写喽

可以使用模型的事件系统做,保存成功后会自动触发 saved 事件,然后监听这个事件,对 B 表做新增即可。

详细可以查看 Eloquent 事件 章节。

4年前 评论

@24K大白羊 createMany 方法去创建多个关联模型不知道能不能实现?

4年前 评论
24K大白羊 4年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!