浅析THINKPHP的addAll支持的最大数据量

前端之家收集整理的这篇文章主要介绍了浅析THINKPHP的addAll支持的最大数据量前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

ThinkPHP中的Model操作有两个方法:add()和addAll

代码如下:@H_301_4@
; $User->add($data); $dataList[] = array('name'=>'thinkphp','email'=>'thinkphp@gamil.com'); $dataList[] = array('name'=>'onethink','email'=>'onethink@gamil.com'); $User->addAll($dataList);

addAll方法可以做到批量添加数据的功能,也就是MySQL的这种用法:

代码如下:@H_301_4@
301_4@

数据量很多情况下尽量选择批量插入而不是循环逐条插入,否则你的数据库会吃不住挂掉。

不过如果你想当然的将所有数据全部存入一个数组并进行addAll也同样会面临挂掉的情况,这是为什么呢?

原因就是MysqL中max_allowed_packet变量的配置限制了上传sql语句的长度,在MysqL配置中将他配置大一点就行了

max_allowed_packet = 100M

同时在插入数据时也做好批量插入的长度限制,毕竟你不知道什么时候数据会变成百万级别的。

以上就是本文的全部内容了,希望小伙伴们能够喜欢。

原文链接:https://www.f2er.com/thinkphp/22727.html

猜你在找的ThinkPHP相关文章