慎用laravel ORM的createMany 与 saveMany

在关联关系一对多和多对多中有两个非常好用的方法,就是createMany与saveMany,可以批量添加或更新,而且我们知道用这两个可以帮我们省去created_at与updated_at这两个字段值的问题(可以执行model中相应的事件),方便确实是方便了,但还是有需要注意的地方的,让我们先来一对多看看源码(多对多也类似):

createMany底层源码

慎用laravel ORM的createMany 与 saveMany

saveMany底层源码

慎用laravel ORM的createMany 与 saveMany

我们可以看到源码其实就是循环去操作的,并不是组合成一句sql去执行,个人感觉循环操作数据库在效率方面是比较低下的,还有一个问题就是如果忘记用事务,循环过程中如果中止会导致数据不一致性的问题

建议

1.两个方法能不用尽量不用
2.小数据量可用,但记得开事务

本作品采用《CC 协议》,转载必须注明作者和本文链接
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 3

不一条一条的的创建,怎么触发模型事件,还是要看场景的,想快速添加,直接insert

2年前 评论
通尼和它的朋友 (楼主) 2年前

整个laravel都没有批量更新的,一般加事务批量处理就好了,没有什么问题!

2年前 评论

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