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 ...
随机推荐
- mybatis xml配置文件模版
mybatis xml配置文件模版 1.mybatis核心配置文件书写(SqlMapConfig.xml) <?xml version="1.0" encoding=&quo ...
- 剑指Offer 8. 跳台阶 (递归)
题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果). 题目地址 https://www.nowcoder.com/pract ...
- VS Code + NWJS(Node-Webkit)0.14.7 + SQLite3 + Angular6 构建跨平台桌面应用
一.项目需求 最近公司有终端桌面系统需求,需要支持本地离线运行(本地数据为主,云端数据同步),同时支持Window XP,最好跨平台.要求安装配置简单(一次性打包安装),安装包要小,安装时间短,可离线 ...
- web(七)css的语法规则、注释
css的语法规则:特殊的css语法标识. !important:当使用多种方式设定标签样式时,设定样式渲染的应用优先权,声明在取值之后. .important { color: red !import ...
- 微信小程序跳转(当我们不知道是普通页面还是tabbar)
页面跳转一般我们都用wx.navigateTo 或者wx.redirectTo等,当页面为tabbar的某一个页面时, 我们盖如何兼容呢我处理的方式为在navigateTo的fail方法中执行wx.s ...
- java-Collection集合、List集合、Vector集合和迭代器Iterator、ListIterator的使用
1.对象数组的概述和使用 * A:案例演示 * 需求:我有5个学生,请把这个5个学生的信息存储到数组中,并遍历数组,获取得到每一个学生信息. * Student[] arr = new Student ...
- paramiko模块(01-04节)、SSH
1. SSH(安全外壳协议) SSH 为 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定:SSH 为建立在应用层基础上的安全协议.SS ...
- 全志A33 lichee 修改开机图片
开发平台 * 芯灵思SinlinxA33开发板 淘宝店铺: https://sinlinx.taobao.com/ 嵌入式linux 开发板交流 QQ:641395230 首先要知道开机图片存在哪里? ...
- xen虚拟化平台虚拟机在线新加一块磁盘无法识别
截图 报错:you need to shutdown and then restart the vm before it can access the new disk 添加好磁盘后按照提示重启虚拟机 ...
- vue企业项目搭建过程(vue-cli脚手架超详细教程 傻瓜-入门)
vue作为现在主流的前端框架,有必要学习一下. vue的官方文档还是不错的,开源中文,一个爽字形容. 如果不是实际开发需要vue-cli构建项目,那么可以在加一个爽. 然而要构建的时候发现官方文档还是 ...