• 技术文章 >后端开发 >PHP问题

    php大量数据入库怎么处理

    (*-*)浩(*-*)浩2019-10-17 09:56:49原创739
    有业务需求需要一次性循环n条数据,插入或更新数据库时,如果单纯的循环,插入/更新,会消耗太多的数据库资源

    以下是一种简单的解决方案

    数据库的insert是可以批量更新的,当有大量数据循环insert时,可以将数据先保留不执行插入命令,到最后一条时一次性插入,例如tp的addAll()方法; (推荐学习:PHP视频教程

    数据库的update 如果使用case when 的话,也是可以批量更新的。

    本文主要讲关于批量insert;

    生成一个订单

    正常情况的语句为:

    INSERT INTO order (`goods_id`,`num`,`price`) VALUES (1,1,'10.00');
    //封装成函数
    function add_order($goods_id,$num,$price){
    $db->query("INSERT INTO order (`goods_id`,`num`,`price`) VALUES ($goods_id,$num,$price)");
    }

    假设有一个用户,一次性将购物车的1000个商品结算成订单,生成1000个订单时;

    for ($i=0;$i<1000;$i++){
    $db->query("INSERT INTO order (`goods_id`,`num`,`price`) VALUES ($goods_id,$num,$price)");
    }
    //这样的话会导致服务器资源占用过大,网站卡死
    //所以,我们可以
    $sql = "INSERT INTO order (`goods_id`,`num`,`price`) VALUES ";
    for ($i=0;$i<1000;$i++){
        if($i==0){
        $sql.="($goods_id,$num,$price)";
        }else{
        $sql.=",($goods_id,$num,$price)";
        }
    }
    $db->query($sql);

    大概意思就是这样了,批量更新实现比较麻烦一点,就不发了,以下是批量更新的sql执行语句

    UPDATE tiyan.dm_user_cupboard SET `res_id` = CASE `id` WHEN 1041 THEN '1' WHEN 1058 THEN '1' WHEN 1055 THEN '1'  END,`food_code` = CASE `id` WHEN 1041 THEN '68' WHEN 1058 THEN '47' WHEN 1055 THEN '49'  END,`food_name` = CASE `id` WHEN 1041 THEN '红枣' WHEN 1058 THEN '莲藕' WHEN 1055 THEN '洋葱'  END,`num` = CASE `id` WHEN 1041 THEN '2' WHEN 1058 THEN '3' WHEN 1055 THEN '2'  END,`level` = CASE `id` WHEN 1041 THEN '2' WHEN 1058 THEN '2' WHEN 1055 THEN '2'  END,`update_time` = CASE `id` WHEN 1041 THEN '2017-12-09 21:40:06' WHEN 1058 THEN '2017-12-09 21:40:06' WHEN 1055 THEN '2017-12-09 21:40:06'  END WHERE id IN ( 1041,1058,1055 )

    以上就是php大量数据入库怎么处理的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:php
    上一篇:php代码属于程序员吗 下一篇:30岁转行php还是java
    PHP编程就业班

    相关文章推荐

    • 在php中添加注释的方法有哪几种?• php到底好不好• php运行过长导致不响应其他请求• iis10支持php吗

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网