PHP优化之批量操作MySQL实例分析
发布:smiling 来源: PHP粉丝网 添加日期:2022-03-02 09:39:15 浏览: 评论:0
本文实例讲述了PHP优化之批量操作MySQL,分享给大家供大家参考,具体如下:
设计一个数据表如下:
- create table optimization(
- id INT NOT NULL AUTO_INCREMENT,
- value VARCHAR(10) NOT NULL,
- PRIMARY KEY(id)
- );
现在有一个业务需求需要批量插入数据。
先来看看下面这一段代码:
- <?php
- $dsn = 'mysql:dbname=test;host=127.0.0.1';
- $user = 'root';
- $password = 'root';
- try {
- $dbh = new PDO($dsn, $user, $password);
- } catch(PDOException $e) {
- echo 'Connection failed: ' , $e->getMessage();
- }
- $begin = microtime(true) * 1000;
- $count = 100;
- $stmt = $dbh->prepare('INSERT INTO `optimization` (id, value) VALUES(:id, :value)');
- $stmt->bindParam(':id', $id);
- $stmt->bindParam(':value', $value);
- for ($i = 0; $i < $count; $i++)
- {
- $id = '';
- $value = $i;
- $stmt->execute();
- }
- $end = microtime(true) * 1000;
- echo 'excuted : ' , ($end - $begin) , ' ms';
经过测试,上面代码运行结果如下:
1、excuted : 7601.4348144531 ms
2、excuted : 7476.4270019531 ms
3、excuted : 7674.4387207031 ms
平均:7584.100179036433 ms
再来看看第二段代码:
- <?php
- $dsn = 'mysql:dbname=test;host=127.0.0.1';
- $user = 'root';
- $password = 'root';
- try {
- $dbh = new PDO($dsn, $user, $password);
- } catch(PDOException $e) {
- echo 'Connection failed: ' , $e->getMessage();
- }
- $begin = microtime(true) * 1000;
- $dbh->beginTransaction();
- try {
- $count = 100;
- $sql = 'INSERT INTO `optimization` (id, value) VALUES ';
- $sql_arr = array();
- $sql_str = '';
- for ($i = 0; $i < $count; $i++)
- {
- $sql_arr[] = ("('', $i)");
- }
- $sql_str = implode(',', $sql_arr);
- $sql .= $sql_str;
- $stmt = $dbh->prepare($sql);
- $stmt->execute();
- $dbh->commit();
- } catch(Exception $e) {
- $dbh->rollBack();
- echo $e->getMessage() . '<br>';
- }
- $end = microtime(true) * 1000;
- echo 'excuted : ' , ($end - $begin) , ' ms';
上面这段代码的运行结果如下:
1、excuted : 99.005859375 ms
2、excuted : 103.00610351562 ms
3、excuted : 68.00390625 ms
平均:90.00528971354 ms
##分析 可以看出,在第二段代码中,使用了批量插入,此时的效率比第一段提高了84%,原因如下:
使用第一段代码的时候,因为每一次循环里都执行了一个mysql语句,此时php需要与mysql获得连接,然后再执行mysql语句,然后再断开。这就是第一段代码最主要的时间开销–PHP与MySQL连接的网络传输IO
第一段代码SQL语句解析的次数更多
因此,在第二段代码中,通过合并SQL语句来实现减少SQL语句解析的次数以及PHP与MySQL连接的次数来达到减少网络传输IO的开销。
注意: 1、SQL语句是有长度限制的,因此,在进行SQL语句合并时务必不能超过SQL长度限制,通过设置max_allowed_packet可以修改,默认是1M,测试时修改为8M。
##总结
在进行对数据库的批量操作(如:插入、更新、修改)时,应当尽可能将SQL语句合并后再执行而不是在循环中依次执行。
记录下最近在项目中犯下的一个比较大的错误,以后不能再犯了,以前一直都没有注意到,直到现在真正参与到企业项目中,自己的代码被老大指出错误后才发现自己的错误,学习了。
Tags: PHP优化 PHP批量操作MySQL
- 上一篇:php实现将数组或对象写入到文件的方法小结【三种方法】
- 下一篇:最后一页
相关文章
- ·PHP性能问题分析+优化(2020-03-04)
- ·简单说说PHP优化那些事(经验分享)(2021-05-01)

推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)