PHP優(yōu)化之批量操作MySQL實(shí)例分析
本文實(shí)例講述了PHP優(yōu)化之批量操作MySQL。分享給大家供大家參考,具體如下:
設(shè)計(jì)一個(gè)數(shù)據(jù)表如下:
create table optimization( id INT NOT NULL AUTO_INCREMENT, value VARCHAR(10) NOT NULL, PRIMARY KEY(id));
現(xiàn)在有一個(gè)業(yè)務(wù)需求需要批量插入數(shù)據(jù)。
先來看看下面這一段代碼:
<?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’;
經(jīng)過測(cè)試,上面代碼運(yùn)行結(jié)果如下:
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’;
上面這段代碼的運(yùn)行結(jié)果如下:
1、excuted : 99.005859375 ms
2、excuted : 103.00610351562 ms
3、excuted : 68.00390625 ms
平均:90.00528971354 ms
##分析 可以看出,在第二段代碼中,使用了批量插入,此時(shí)的效率比第一段提高了84%。原因如下:
使用第一段代碼的時(shí)候,因?yàn)槊恳淮窝h(huán)里都執(zhí)行了一個(gè)mysql語句,此時(shí)php需要與mysql獲得連接,然后再執(zhí)行mysql語句,然后再斷開。這就是第一段代碼最主要的時(shí)間開銷?PHP與MySQL連接的網(wǎng)絡(luò)傳輸IO 第一段代碼SQL語句解析的次數(shù)更多因此,在第二段代碼中,通過合并SQL語句來實(shí)現(xiàn)減少SQL語句解析的次數(shù)以及PHP與MySQL連接的次數(shù)來達(dá)到減少網(wǎng)絡(luò)傳輸IO的開銷。
注意: 1、SQL語句是有長度限制的,因此,在進(jìn)行SQL語句合并時(shí)務(wù)必不能超過SQL長度限制,通過設(shè)置max_allowed_packet可以修改,默認(rèn)是1M,測(cè)試時(shí)修改為8M。
##總結(jié)
在進(jìn)行對(duì)數(shù)據(jù)庫的批量操作(如:插入、更新、修改)時(shí),應(yīng)當(dāng)盡可能將SQL語句合并后再執(zhí)行而不是在循環(huán)中依次執(zhí)行。
記錄下最近在項(xiàng)目中犯下的一個(gè)比較大的錯(cuò)誤,以后不能再犯了。以前一直都沒有注意到,直到現(xiàn)在真正參與到企業(yè)項(xiàng)目中,自己的代碼被老大指出錯(cuò)誤后才發(fā)現(xiàn)自己的錯(cuò)誤。學(xué)習(xí)了。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php+mysql數(shù)據(jù)庫操作入門教程》、《php+mysqli數(shù)據(jù)庫程序設(shè)計(jì)技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章:
1. vue組件庫的在線主題編輯器的實(shí)現(xiàn)思路2. 如何用 Python 制作一個(gè)迷宮游戲3. 部署vue+Springboot前后端分離項(xiàng)目的步驟實(shí)現(xiàn)4. Django如何使用asyncio協(xié)程和ThreadPoolExecutor多線程5. AspNetCore&MassTransit Courier實(shí)現(xiàn)分布式事務(wù)的詳細(xì)過程6. idea設(shè)置自動(dòng)導(dǎo)入依賴的方法步驟7. 網(wǎng)頁中img圖片使用css實(shí)現(xiàn)等比例自動(dòng)縮放不變形(代碼已測(cè)試)8. Python安裝并操作redis實(shí)現(xiàn)流程詳解9. ASP常用日期格式化函數(shù) FormatDate()10. JavaScript實(shí)現(xiàn)組件化和模塊化方法詳解
