php导入大量数据到mysql性能优化技巧


Posted in PHP onDecember 29, 2014

本文实例讲述了php导入大量数据到mysql性能优化技巧。分享给大家供大家参考。具体分析如下:

在mysql中我们结合php把一些文件导入到mysql中,这里就来分享一下我对15000条记录进行导入时分析与优化,需要的朋友可以参考一下.

之前有几篇文章,说了最近tiandi在帮朋友做一个小项目,用于统计电话号码的,每次按需求从数据库里随机生成打包的电话号码,然后不停地让人打这些电话号码推销产品(小小鄙视一下这样的行为)。但是朋友要求帮忙,咱也不能不帮啊,是吧。程序两个星期前已经做好,测试完毕交工。前几天朋友来电说,每天导入电话号码的时间越来越长,有时候一万条记录就要半个小时以上,看看能不能想办法提高一下这个速度。

我理了一下思路,数据库结构很简单,可以认为就两个字段,一个字段存电话号码,另一字段存类别,类别分别为c,d,e等等,分别代表已经拨通过此电话,未拨通过此电话,未拨打过此电话等等状态,而整个程序逻辑是这样的.

■拿到一个txt文件,里面存的是电话号码

■通过程序将txt文件导入到mysql里

■导入的时候,检测txt里的电话号码是否和mysql里的重复,如果不重复,直接插入新记录,如果重复,就需要按照判断电话号码所属类别来进行更新。

由于每个txt里的电话号码导入时,都需要做一次比较,所以程序肯定会耗时一些,这里我们先撇开这个原因,因为本文章的标题是优化写入速度,那么程序什么时候会写入记录呢?通过上面的逻辑得知,在匹配数据库时,没有发现存在记录时会发生写入数据库操作(当然update也算,只是这里只讨论insert),那么将上述逻辑转化为代码,差不多如下:

//$array为txt文件explode出来的数组,每一个为一个电话号码, $str为类型 

for($i=0; $i<count($array); $i++)  

{  

        $tmpstr = "'". $array[$i] ."','". $str ."'"; 

        $sql="INSERT INTO ".$usertable." (tel,type) VALUES (".$tmpstr.")"; 

        mysql_query($sql); 

}

以上代码完全正确,但是效率低下,当txt文件里包含了上万个电话号码时,即会有上万次的插入数据库操作,虽然每次的数据库写入操作都是很快的,但是上万条累计下来,这个执行时间不容忽视,tiandi简单的测试了一下插入15000万条记录,耗时差不多5分钟,如果再加上之前的逻辑判断等等过程,那么半个小时还真得不算少了,这样可不行,必须减少数据库库写入次数才对,于是上面代码变更为以下:
$sql2="INSERT INTO ".$usertable." (tel,type,updatetime) VALUES"; 

for($i=0; $i<count($array); $i++)  

{  

        $tmpstr = "'". $array[$i] ."','". $str ."'"; 

 $sql2 .= "(".$tmpstr."),"; 

} 

$sql2 = substr($sql2,0,-1);   //去除最后的逗号 

mysql_query($sql2);

这样,整个写入操作只有1次,大大地缩短了执行时间,差不多10秒就搞定了15000条记录,好了,本文到此结束,如果你也遇上写入大量数据到mysql耗时长的问题时,不如试试本文的优化方式.

希望本文所述对大家的php程序设计有所帮助。

PHP 相关文章推荐
表单复选框向PHP传输数据的代码
Nov 13 PHP
PHP 数组基础知识小结
Aug 20 PHP
php中socket的用法详解
Oct 24 PHP
PHP实现HTML生成PDF文件的方法
Nov 07 PHP
PHP程序员必须清楚的问题汇总
Dec 18 PHP
PHP中error_reporting函数用法详细介绍
Jun 11 PHP
php使用ftp实现文件上传与下载功能
Jul 21 PHP
完美的php分页类
Oct 24 PHP
PHP实现防止表单重复提交功能【基于token验证】
May 24 PHP
PHP的PDO大对象(LOBs)
Jan 27 PHP
Laravel 验证码认证学习记录小结
Dec 20 PHP
PHP变量的作用范围实例讲解
Dec 22 PHP
推荐几个开源的微信开发项目
Dec 28 #PHP
dedecms集成财付通支付接口
Dec 28 #PHP
VPS中使用LNMP安装WordPress教程
Dec 28 #PHP
php随机取mysql记录方法小结
Dec 27 #PHP
php使用PDO方法详解
Dec 27 #PHP
PHP把MSSQL数据导入到MYSQL的方法
Dec 27 #PHP
php将图片保存入mysql数据库失败的解决方法
Dec 27 #PHP
You might like
PHP新手用的Insert和Update语句构造类
2012/03/31 PHP
PHP微信开发之微信录音临时转永久存储
2018/01/26 PHP
JQuery Dialog的内存泄露问题解决方法
2010/06/18 Javascript
js类型检查实现代码
2010/10/29 Javascript
js中document.getElementByid、document.all和document.layers区分介绍
2011/12/08 Javascript
js获取键盘按键响应事件(兼容各浏览器)
2013/05/16 Javascript
JavaScript的类型、值和变量小结
2015/07/09 Javascript
javascript中JSON对象与JSON字符串相互转换实例
2015/07/11 Javascript
javascript实现鼠标移到Image上方时显示文字效果的方法
2015/08/07 Javascript
confirm确认对话框的实现方法总结
2016/06/17 Javascript
AngularJS在IE下取数据总是缓存问题的解决方法
2016/08/05 Javascript
jQuery EasyUI Draggable拖动组件
2017/03/01 Javascript
axios基本入门用法教程
2017/03/25 Javascript
基于input框覆盖掉数字英文的实例讲解
2017/07/21 Javascript
JavaScript中递归实现的方法及其区别
2017/09/12 Javascript
ES6下子组件调用父组件的方法(推荐)
2018/02/23 Javascript
vue2.x集成百度UEditor富文本编辑器的方法
2018/09/21 Javascript
微信小程序实现带缩略图轮播效果
2018/11/04 Javascript
微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析
2019/08/16 Javascript
Vue打包部署到Nginx时,css样式不生效的解决方式
2020/08/03 Javascript
javascript中导出与导入实现模块化管理教程
2020/12/03 Javascript
Python3通过Luhn算法快速验证信用卡卡号的方法
2015/05/14 Python
Python中集合的内建函数和内建方法学习教程
2015/08/19 Python
详解python单例模式与metaclass
2016/01/15 Python
Python如何import文件夹下的文件(实现方法)
2017/01/24 Python
python opencv实现运动检测
2018/07/10 Python
Appium+Python自动化测试之运行App程序示例
2019/01/23 Python
Python实现最大子序和的方法示例
2019/07/05 Python
flask应用部署到服务器的方法
2019/07/12 Python
python获取系统内存占用信息的实例方法
2020/07/17 Python
农民工讨薪标语
2014/06/26 职场文书
预备党员转正思想汇报
2014/09/26 职场文书
卖房协议书样本
2014/10/30 职场文书
大学生个人学年总结
2015/02/15 职场文书
仰望星空观后感
2015/06/10 职场文书
MySQL中连接查询和子查询的问题
2021/09/04 MySQL