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 ...
随机推荐
- format 插入一个字符,%d,%n
- SpringBoot(三)thymeleaf+JPA+MySql
接着上一节的 第一步:在pom文件中加入以下代码: <!--JPA--> <dependency> <groupId>org.springframework.boo ...
- jdbc “贾琏欲执事”
“贾琏欲执事” 1.加载驱动2.获取连接3.SQL语句4.执行SQL5.释放资源 示例: public void test_insert() { String driver="oracle. ...
- centos7.5 安装mysql8.0.13
在Linux系统上使用rpm包管理器安装mysql Installing MySQL on Linux Using RPM Packages 环境:CentOS Linux release 7.4.1 ...
- 关于C#中break和continue的认识
1.在昨天我在做循环处理的时候,遇到了break和continue的使用问题,今天来总结了一下, break: for (int i=0;i<5;i++) { a++; if(a==1) bre ...
- jQuery-2.DOM---节点的复制与替换
DOM拷贝clone() 克隆节点是DOM的常见操作,jQuery提供一个clone方法,专门用于处理dom的克隆 .clone()方法深度 复制所有匹配的元素集合,包括所有匹配元素.匹配元素的下级元 ...
- CSS3 transform变形(3D转换)
一.三维坐标 空间中三维坐标如下图所示: 向上为-Y,向下为+Y,向左为-X,向右为+X,向前为+Z,向后为-Z. 二.perspective(n)为 3D 转换元素定义透视视图 perspectiv ...
- Gym101889E. Enigma(bfs+数位)
比赛链接:传送门 题目大意: 求一个十进制大数S(有部分数位为"?")能被N整除时的最小值,如果没有办法被N整除,输出"*". 思路: 一个数位上的数值增加1后 ...
- 12.python-metaclass元类
1.python中一切皆是对象,类本身也是一个对象,当使用关键字class的时候,python解释器在加载class的时候会创建一个对象(这里的对象指的是类而非类的实例) class Foo: #cl ...
- 学习笔记(二)--Lucene简介
Lucene简介 最受欢迎的java开源全文搜索引擎开发工具包.提供了完整的查询引擎和索引引擎,部分文本分词引擎(英文与德文两种西方语言).Lucene的目的是为软件开发人员提供一个简单易用的工具包, ...