多表写入数据如何实现?

当前有表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); // 正常打印结果
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 3

这个就需要自己写喽

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

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

4年前 评论

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

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

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