关于thinkphp的addall支持的最大数据量,thinkphpaddallthinkphp中的model操作有两个方法:add()和addall
1 $user = m(user); // 实例化user对象2 $data['name'] = 'thinkphp';3 $data['email'] = 'thinkphp@gmail.com';4 $user->add($data);5 6 $datalist[] = array('name'=>'thinkphp','email'=>'thinkphp@gamil.com');7 $datalist[] = array('name'=>'onethink','email'=>'onethink@gamil.com');8 $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
同时在插入数据时也做好批量插入的长度限制,毕竟你不知道什么时候数据会变成百万级别的。
http://www.bkjia.com/phpjc/951419.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/951419.htmltecharticle关于thinkphp的addall支持的最大数据量,thinkphpaddall thinkphp中的model操作有两个方法:add()和addall 1 $user = m(user); // 实例化user对象 2 $data ['name'...