浅析THINKPHP的addAll支持的最大数据量_PHP
程序员文章站
2022-04-07 08:53:00
...
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
同时在插入数据时也做好批量插入的长度限制,毕竟你不知道什么时候数据会变成百万级别的。
以上就是本文的全部内容了,希望小伙伴们能够喜欢。
上一篇: laravel的分页问题实例
推荐阅读
-
浅析THINKPHP的addAll支持的最大数据量_php实例
-
ThinkPHP3.1新特性之多层MVC的支持_PHP教程
-
浅析THINKPHP的addAll支持的最大数据量,thinkphpaddall_PHP教程
-
浅析ThinkPHP中execute和query方法的区别_PHP教程
-
THINKPHP支持YAML配置文件的设置方法_php技巧
-
ThinkPHP3.1新特性之对分组支持的改进与完善概述_PHP教程
-
浅析THINKPHP的addAll支持的最大数据量
-
解决nginx不支持thinkphp中pathinfo的问题_PHP
-
ThinkPHP的PHP变量传送到模板原理浅析
-
浅析ThinkPHP中execute和query方法的区别_php实例