色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

PHP優化之批量操作MySQL實例分析

瀏覽:115日期:2022-09-10 16:45:59

本文實例講述了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語句合并后再執行而不是在循環中依次執行。

記錄下最近在項目中犯下的一個比較大的錯誤,以后不能再犯了。以前一直都沒有注意到,直到現在真正參與到企業項目中,自己的代碼被老大指出錯誤后才發現自己的錯誤。學習了。

更多關于PHP相關內容感興趣的讀者可查看本站專題:《php+mysql數據庫操作入門教程》、《php+mysqli數據庫程序設計技巧總結》、《php面向對象程序設計入門教程》、《PHP數組(Array)操作技巧大全》、《php字符串(string)用法總結》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

標簽: PHP
相關文章:
主站蜘蛛池模板: 日韩城人视频 | 看真人一级毛片 | 久草网首页 | 亚洲视频免费在线看 | 小草青青神马影院 | 亚洲成人黄色片 | 国产护士一级毛片高清 | 天天看片天天爽_免费播放 天天看夜夜 | 欧美一区中文字幕 | 国产农村乱 | 91 久久| 夜间福利在线观看 | 欧美日韩成人在线视频 | 亚州三级视频 | 日韩在线1| 欧美成人鲁丝片在线观看 | 日韩欧美一区二区中文字幕 | 欧美视频一区二区三区在线观看 | 亚洲国产一区二区三区四区五区 | 九九九热在线精品免费全部 | 国产ssss在线观看极品 | 国产精品成人一区二区不卡 | 国产成在线观看免费视频成本人 | 成人黄色在线网站 | 国模肉肉人体大尺度啪啪 | 欧美三级三级三级爽爽爽 | 国产专区在线 | 亚洲成人影院在线观看 | 久久精品三级视频 | 成人18网址在线观看 | a级国产乱理伦片在线观看国 | 日本久久香蕉一本一道 | 久草免费资源在线 | 美女视频一区二区三区 | 日韩国产中文字幕 | 福利片成人午夜在线 | 久久午夜精品视频 | 亚洲欧美日韩中文字幕在线一 | 中文字幕天堂久久精品 | 久国产精品视频 | 欧美一级毛片无遮无挡 |