zoukankan      html  css  js  c++  java
  • 关于THINKPHP的addAll支持的最大数据量

    Thinkphp中的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


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

  • 相关阅读:
    python爬取哦漫画
    NLP系列(2)_用朴素贝叶斯进行文本分类(上)
    svm 笔记
    nlp学习笔记
    LR
    bp网络全解读
    最小二乘法
    学习参考
    pandas中的quantile函数
    泰坦尼克号与小费与乘客数量与 鸢尾花数据集
  • 原文地址:https://www.cnblogs.com/hornedreaper1988/p/4266716.html
Copyright © 2011-2022 走看看