php一次性大量数据入库解决方法
当有业务需求需要一次性循环n条数据,插入或更新数据库时,如果单纯的循环,插入/更新,会消耗太多的数据库资源
一下是一种简单的解决方案
数据库的insert 是可以批量更新的,当有大量数据循环insert时,可以将数据先保留不执行插入命令,到最后一条时一次性插入,例如tp的addAll()方法;
数据库的update 如果使用case when 的话,也是可以批量更新的,本人在百度上找到了一个基于tp的saveAll()方法,用于更新数据
本文主要讲关于批量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 )
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 )
附带基于tp的saveAll()
//批量更新
public
function
saveAll(
$datas
,
$model
){
(
$model
||
$model
=
$this
->tableName);
$model
=
empty
(
$model
)?
$this
->name:
$model
;
$sql
=
''
;
//Sql
$lists
= [];
//记录集$lists
$pk
=
$this
->getPk();
//获取主键
foreach
(
$datas
as
$data
) {
foreach
(
$data
as
$key
=>
$value
) {
if
(
$pk
===
$key
){
$ids
[]=
$value
;
}
else
{
$lists
[
$key
].= sprintf(
"WHEN %u THEN '%s' "
,
$data
[
$pk
],
$value
);
}
}
}
foreach
(
$lists
as
$key
=>
$value
) {
$sql
.= sprintf(
"`%s` = CASE `%s` %s END,"
,
$key
,
$pk
,
$value
);
}
$sql
= sprintf(
'UPDATE __%s__ SET %s WHERE %s IN ( %s )'
,
strtoupper
(
$model
),rtrim(
$sql
,
','
),
$pk
,implode(
','
,
$ids
));
return
M()->execute(
$sql
);
}
php一次性大量数据入库解决方法的更多相关文章
- SQLServerException:将截断字符串或二进制数据的解决方法
SQLServerException:将截断字符串或二进制数据的解决方法: 最近使用JPA进行保存对象到数据库中怎么也添加不进去,始终报错 主要原因就是你增加的数据字段长度超过数据库中字段所定义长度, ...
- resultMap中的collection集合出现只能读取一条数据的解决方法
查询数据时只能获得collection集合中的的一条数据,相关情况如下: 结果集resultMap: <resultMap id="ManagerRolesAcls" typ ...
- .NET MVC Json()处理大数据异常解决方法
[1-部分原文]: .NET MVC Json()处理大数据异常解决方法 整个项目采用微软的ASP.NET MVC3进行开发,前端显示采用EasyUI框架,图表的显示用的是Highcharts,主要进 ...
- buttongroup中content一次性加载的解决方法
buttongroup一次性加载所有内容的解决方法 如下图所示: 第一步: 设置windowcontainer的autoLoad属性为false(默认情况下autoLoad属性为true,所以会加载所 ...
- Hive数据倾斜解决方法总结
数据倾斜是进行大数据计算时最经常遇到的问题之一.当我们在执行HiveQL或者运行MapReduce作业时候,如果遇到一直卡在map100%,reduce99%一般就是遇到了数据倾斜的问题.数据倾斜其实 ...
- Jquery的ajax在IE提交数据乱码解决方法
原文地址:http://fatkun.com/2010/12/jquery-ajax.html 乱码是因为编码不同而造成的.在ajax post 或 get时都有可能出现乱码. 为了避免乱码,可以做到 ...
- Spring初始化完成后直接执行一个方法,初始化数据(解决方法被重复执行两次的情况)
在做WEB项目时,经常在项目第一次启动时利用WEB容器的监听.Servlet加载初始化等切入点为数据库准备数据,这些初始化数据 是系统开始运行前必须的数据,例如权限组.系统选项.默认管理员等等.但是项 ...
- el表达式无法获取springmvc的model封装好的数据之解决方法
近日碰到奇怪的问题,应该挺好解决的,可是就是卡住我两天 下面我来描述一下问题 用的是springmvc,自然需要controller,假设我现在所有的配置都是对的. controller代码 @Req ...
- esayUi中datagrid中json串为空时,显示上一次数据的解决方法
function initSearchProject(startDate,finishDate,flag) { $("#finishDate").val(finish ...
随机推荐
- ASP.NET MVC 阻止通过Url直接访问服务器上的静态文件
某些情况下我们需要在服务器上保存一些静态文件,比如用户上传到服务器的文件,如果刚好这些文件的保存目录是应用程序目录下的一个子目录的话,别人就可以通过Url直接访问这个文件. 例如:在应用程序目录下的U ...
- 莫烦tensorflow(9)-Save&Restore
import tensorflow as tfimport numpy as np ##save to file#rember to define the same dtype and shape w ...
- Javascript Canvas验证码
用Canvas画的验证码,效果图如下 1.验证码的JS代码,保存到一个名称是validatedCode.js的文件内,代码如下: (function(window,document){ functio ...
- 项目三(2)——person与学生
编程实现Person类,学生类的设计及其继承关系 (同第六章课后第三题) class Person{ private String name; private String addr; private ...
- vs2017 编译vue 错误 TS2307 Build:找不到模块“webpack”。
升级了vs2017之后,编译之前正常的工程,发现出现了对vue的编译错误, 提示一些列找不到模块的错误 错误 TS2307 Build:找不到模块“webpack”. ...... 错误 TS2345 ...
- Linux下,用命令进行 日志分割、日志合并
指定文件大小分割: split -b 10m catalina.out imsoft 以每个文本文件10M方式分割日志 文件合并: cat small_file* > large_file
- XML一
HTML(HyperText Markup Language),即超文本标记语言,是用于描述网页文档的一种描述标记语言. 而XML(E ...
- 2分钟理解文件IO -我对文件IO的理解与实验对比
本文介绍了不同的IO方式以及他们之间的效率比较 1.一次读取写入单个字节(读取400M的文件浪费了很久,等了很久没读取完成,证明其效率很差) public class CopyFileDemo { p ...
- cookie mapping 原理理解
深入浅出理解 COOKIE MAPPING Cookie mapping技术 利用javascript跨域访问cookie之广告推广
- 第十一章 IO流
11.IO流 11.1 java.io.File类的使用 1课时 11.2 IO原理及流的分类 1课时 11.3 节点流(或文件流) 1课时 11.4 缓冲流 1课时 11.5 转换流 1课时 11. ...