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实现小型站点广告管理(修正版)
Oct 09 PHP
PHP操作mysql函数详解,mysql和php交互函数
May 19 PHP
hadoop常见错误以及处理方法详解
Jun 19 PHP
在PHP模板引擎smarty生成随机数的方法和math函数详解
Apr 24 PHP
PHP中的魔术方法总结和使用实例
May 11 PHP
php递归实现无限分类的方法
Jul 28 PHP
php经典算法集锦
Nov 14 PHP
Yii2针对指定url的生成及图片等的引入方法小结
Jul 18 PHP
PHP getDocNamespaces()函数讲解
Feb 03 PHP
PHP实现提高SESSION响应速度的几种方法详解
Aug 09 PHP
PHP开发api接口安全验证操作实例详解
Mar 26 PHP
PHP实现rar解压读取扩展包小结
Jun 03 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文件上传你必须知道的几点
2015/10/20 PHP
PHP封装的XML简单操作类完整实例
2017/11/13 PHP
PHP中有关长整数的一些操作教程
2019/09/11 PHP
从父页面读取和操作iframe中内容方法
2009/07/25 Javascript
关于使用 jBox 对话框的提交不能弹出问题解决方法
2012/11/07 Javascript
jQuery搜索子元素的方法
2015/02/10 Javascript
JavaScript数据类型判定的总结笔记
2015/07/31 Javascript
学习JavaScript图片预加载模块
2016/11/07 Javascript
使用nodejs下载风景壁纸
2017/02/05 NodeJs
canvas实现爱心和彩虹雨效果
2017/03/09 Javascript
从零开始学习Node.js系列教程一:http get和post用法分析
2017/04/13 Javascript
nodejs6下使用koa2框架实例
2017/05/18 NodeJs
用element的upload组件实现多图片上传和压缩的示例代码
2019/02/12 Javascript
微信小程序实现手指拖动选项排序
2020/04/22 Javascript
Vue执行方法,方法获取data值,设置data值,方法传值操作
2020/08/05 Javascript
[46:23]OG vs EG 2018国际邀请赛淘汰赛BO3 第一场 8.23
2018/08/24 DOTA
python判断图片宽度和高度后删除图片的方法
2015/05/22 Python
Python中的Descriptor描述符学习教程
2016/06/02 Python
Python selenium文件上传方法汇总
2020/11/19 Python
Python简单格式化时间的方法【strftime函数】
2016/09/18 Python
Python 装饰器实现DRY(不重复代码)原则
2018/03/05 Python
Python中使用pypdf2合并、分割、加密pdf文件的代码详解
2019/05/21 Python
Django  ORM 练习题及答案
2019/07/19 Python
Python 硬币兑换问题
2019/07/29 Python
Django Aggregation聚合使用方法解析
2019/08/01 Python
如何基于windows实现python定时爬虫
2020/05/01 Python
python pyg2plot的原理知识点总结
2021/02/28 Python
Bjorn Borg官方网上商店:国际运动时尚品牌
2016/08/27 全球购物
迷你分体式空调:SoGoodToBuy
2018/08/07 全球购物
学习决心书范文
2014/03/11 职场文书
卫校毕业生个人自我鉴定
2014/04/28 职场文书
七夕活动策划方案
2014/08/16 职场文书
公司酒会致辞
2015/07/30 职场文书
爱国主题班会教案
2015/08/14 职场文书
亲情作文之母爱
2019/09/25 职场文书
python3读取文件指定行的三种方法
2021/05/24 Python