Rumah >pembangunan bahagian belakang >masalah PHP >php大量数据入库怎么处理

php大量数据入库怎么处理

(*-*)浩
(*-*)浩asal
2019-10-17 09:56:492217semak imbas

有业务需求需要一次性循环n条数据,插入或更新数据库时,如果单纯的循环,插入/更新,会消耗太多的数据库资源

php大量数据入库怎么处理

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

数据库的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 &#39;1&#39; WHEN 1058 THEN &#39;1&#39; WHEN 1055 THEN &#39;1&#39;  END,`food_code` = CASE `id` WHEN 1041 THEN &#39;68&#39; WHEN 1058 THEN &#39;47&#39; WHEN 1055 THEN &#39;49&#39;  END,`food_name` = CASE `id` WHEN 1041 THEN &#39;红枣&#39; WHEN 1058 THEN &#39;莲藕&#39; WHEN 1055 THEN &#39;洋葱&#39;  END,`num` = CASE `id` WHEN 1041 THEN &#39;2&#39; WHEN 1058 THEN &#39;3&#39; WHEN 1055 THEN &#39;2&#39;  END,`level` = CASE `id` WHEN 1041 THEN &#39;2&#39; WHEN 1058 THEN &#39;2&#39; WHEN 1055 THEN &#39;2&#39;  END,`update_time` = CASE `id` WHEN 1041 THEN &#39;2017-12-09 21:40:06&#39; WHEN 1058 THEN &#39;2017-12-09 21:40:06&#39; WHEN 1055 THEN &#39;2017-12-09 21:40:06&#39;  END WHERE id IN ( 1041,1058,1055 )

Atas ialah kandungan terperinci php大量数据入库怎么处理. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:php代码属于程序员吗Artikel seterusnya:30岁转行php还是java