這篇文章主要介紹“PHP優(yōu)化之如何批量操作MySQL”,在日常操作中,相信很多人在PHP優(yōu)化之如何批量操作MySQL問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”PHP優(yōu)化之如何批量操作MySQL”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
創(chuàng)新互聯(lián)公司IDC提供業(yè)務(wù):重慶服務(wù)器托管,成都服務(wù)器租用,重慶服務(wù)器托管,重慶服務(wù)器租用等四川省內(nèi)主機托管與主機租用業(yè)務(wù);數(shù)據(jù)中心含:雙線機房,BGP機房,電信機房,移動機房,聯(lián)通機房。設(shè)計一個數(shù)據(jù)表如下:
create table optimization( id INT NOT NULL AUTO_INCREMENT, value VARCHAR(10) NOT NULL, PRIMARY KEY(id) );
現(xiàn)在有一個業(yè)務(wù)需求需要批量插入數(shù)據(jù)。
先來看看下面這一段代碼:
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)過測試,上面代碼運行結(jié)果如下:
1、excuted : 7601.4348144531 ms
2、excuted : 7476.4270019531 ms
3、excuted : 7674.4387207031 ms
平均:7584.100179036433 ms
再來看看第二段代碼:
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() . '
'; } $end = microtime(true) * 1000; echo 'excuted : ' , ($end - $begin) , ' ms';
上面這段代碼的運行結(jié)果如下:
1、excuted : 99.005859375 ms
2、excuted : 103.00610351562 ms
3、excuted : 68.00390625 ms
平均:90.00528971354 ms
##分析 可以看出,在第二段代碼中,使用了批量插入,此時的效率比第一段提高了84%。原因如下:
使用第一段代碼的時候,因為每一次循環(huán)里都執(zhí)行了一個mysql語句,此時php需要與mysql獲得連接,然后再執(zhí)行mysql語句,然后再斷開。這就是第一段代碼最主要的時間開銷–PHP與MySQL連接的網(wǎng)絡(luò)傳輸IO
第一段代碼SQL語句解析的次數(shù)更多
因此,在第二段代碼中,通過合并SQL語句來實現(xiàn)減少SQL語句解析的次數(shù)以及PHP與MySQL連接的次數(shù)來達(dá)到減少網(wǎng)絡(luò)傳輸IO的開銷。
注意: 1、SQL語句是有長度限制的,因此,在進(jìn)行SQL語句合并時務(wù)必不能超過SQL長度限制,通過設(shè)置max_allowed_packet可以修改,默認(rèn)是1M,測試時修改為8M。
##總結(jié)
在進(jìn)行對數(shù)據(jù)庫的批量操作(如:插入、更新、修改)時,應(yīng)當(dāng)盡可能將SQL語句合并后再執(zhí)行而不是在循環(huán)中依次執(zhí)行。
記錄下最近在項目中犯下的一個比較大的錯誤,以后不能再犯了。以前一直都沒有注意到,直到現(xiàn)在真正參與到企業(yè)項目中,自己的代碼被老大指出錯誤后才發(fā)現(xiàn)自己的錯誤。學(xué)習(xí)了。
到此,關(guān)于“PHP優(yōu)化之如何批量操作MySQL”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
網(wǎng)頁名稱:PHP優(yōu)化之如何批量操作MySQL-創(chuàng)新互聯(lián)
地址分享:http://weahome.cn/article/gidgo.html