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ù)。
先來(lái)看看下面這一段代碼:
<?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)過(guò)測(cè)試,上面代碼運(yùn)行結(jié)果如下:
1、excuted : 7601.4348144531 ms
2、excuted : 7476.4270019531 ms
3、excuted : 7674.4387207031 ms
平均:7584.100179036433 ms
再來(lái)看看第二段代碼:
<?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語(yǔ)句,此時(shí)php需要與mysql獲得連接,然后再執(zhí)行mysql語(yǔ)句,然后再斷開(kāi)。這就是第一段代碼最主要的時(shí)間開(kāi)銷–PHP與MySQL連接的網(wǎng)絡(luò)傳輸IO
- 第一段代碼SQL語(yǔ)句解析的次數(shù)更多
因此,在第二段代碼中,通過(guò)合并SQL語(yǔ)句來(lái)實(shí)現(xiàn)減少SQL語(yǔ)句解析的次數(shù)以及PHP與MySQL連接的次數(shù)來(lái)達(dá)到減少網(wǎng)絡(luò)傳輸IO的開(kāi)銷。
注意: 1、SQL語(yǔ)句是有長(zhǎng)度限制的,因此,在進(jìn)行SQL語(yǔ)句合并時(shí)務(wù)必不能超過(guò)SQL長(zhǎng)度限制,通過(guò)設(shè)置max_allowed_packet可以修改,默認(rèn)是1M,測(cè)試時(shí)修改為8M。
##總結(jié)
在進(jìn)行對(duì)數(shù)據(jù)庫(kù)的批量操作(如:插入、更新、修改)時(shí),應(yīng)當(dāng)盡可能將SQL語(yǔ)句合并后再執(zhí)行而不是在循環(huán)中依次執(zhí)行。
記錄下最近在項(xiàng)目中犯下的一個(gè)比較大的錯(cuò)誤,以后不能再犯了。以前一直都沒(méi)有注意到,直到現(xiàn)在真正參與到企業(yè)項(xiàng)目中,自己的代碼被老大指出錯(cuò)誤后才發(fā)現(xiàn)自己的錯(cuò)誤。學(xué)習(xí)了。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php+mysql數(shù)據(jù)庫(kù)操作入門教程》、《php+mysqli數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP自動(dòng)識(shí)別字符集并完成轉(zhuǎn)碼詳解
話不多說(shuō),直接上函數(shù),這個(gè)函數(shù)是用來(lái)對(duì)字符串進(jìn)行檢查和轉(zhuǎn)碼的。需要的朋友可以過(guò)來(lái)參考下2013-08-08
如何使用FireFox插件FirePHP調(diào)試PHP
使用這個(gè)工具,首先你需要安裝FirePHP插件。這個(gè)插件需要你已經(jīng)安裝FireBug。裝好FirePHP之后,重新打開(kāi)Firebug面板時(shí)候,你會(huì)看到新加了一個(gè)藍(lán)色的臭蟲(chóng)圖標(biāo)。點(diǎn)擊這個(gè)圖標(biāo)會(huì)出現(xiàn)一個(gè)開(kāi)啟或者關(guān)閉FirePHP的菜單2013-07-07
對(duì)PHP PDO的一些認(rèn)識(shí)小結(jié)
這篇文章主要介紹了對(duì)PHP PDO的一些認(rèn)識(shí)小結(jié),本文講解了什么是PDO、啟用PDO的配置方法、PDO的預(yù)定義類、事務(wù)處理例子等內(nèi)容,需要的朋友可以參考下2015-01-01
PHP使用GETDATE獲取當(dāng)前日期時(shí)間作為一個(gè)關(guān)聯(lián)數(shù)組的方法
這篇文章主要介紹了PHP使用GETDATE獲取當(dāng)前日期時(shí)間作為一個(gè)關(guān)聯(lián)數(shù)組的方法,實(shí)例分析了php中GETDATE函數(shù)使用技巧,需要的朋友可以參考下2015-03-03
thinkphp5使用bootstrapvalidator進(jìn)行異步驗(yàn)證郵箱的示例
這篇文章主要介紹了thinkphp5使用bootstrapvalidator進(jìn)行異步驗(yàn)證郵箱的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
PHP接口繼承及接口多繼承原理與實(shí)現(xiàn)方法詳解
這篇文章主要介紹了PHP接口繼承及接口多繼承原理與實(shí)現(xiàn)方法,簡(jiǎn)單描述了接口繼承與多接口繼承的概念、原理,并結(jié)合實(shí)例形式給出了php接口繼承的具體實(shí)現(xiàn)與使用等操作技巧,需要的朋友可以參考下2017-10-10
一個(gè)經(jīng)典實(shí)用的PHP圖像處理類分享
這篇文章主要介紹了一個(gè)經(jīng)典實(shí)用的PHP圖像處理類分享,本文提供的PHP圖像操作類可以滿足網(wǎng)站中的大部分功能需求,如圖片的縮放、加水印和裁剪等功能,需要的朋友可以參考下2014-11-11

