当前位置:实例文章 » PHP实例» [文章]浅析THINKPHP的addAll支持的最大数据量

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

发布人:shili8 发布时间:2022-11-30 06:02 阅读次数:27

thinkphp中的model操作有两个方法:add()和addall

复制代码 代码如下:

?$user = m("user"); // 实例化user对象
?$data['name'] = 'thinkphp';
?$data['email'] = 'thinkphp@gmail.com';
?$user->add($data);
?$datalist[] = array('name'=>'thinkphp','email'=>'thinkphp@gamil.com');
?$datalist[] = array('name'=>'onethink','email'=>'onethink@gamil.com');
?$user->addall($datalist);

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

复制代码 代码如下:

insert into tbl_name (a,b,c) values(1,2,3),(4,5,6),(7,8,9);

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

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

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

max_allowed_packet = 100m

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

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

相关标签:

免责声明

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱290110527@qq.com删除。

其他信息

其他资源

Top