佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > PHP優(yōu)化之批量操作MySQL實(shí)例分析

PHP優(yōu)化之批量操作MySQL實(shí)例分析

熱門(mén)標(biāo)簽:科大訊飛語(yǔ)音識(shí)別系統(tǒng) Linux服務(wù)器 電子圍欄 阿里云 服務(wù)器配置 團(tuán)購(gòu)網(wǎng)站 Mysql連接數(shù)設(shè)置 銀行業(yè)務(wù)

本文實(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)銷(xiāo)–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)銷(xiāo)。

注意: 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)容感興趣的讀者可查看本站專(zhuān)題:《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》、《php+mysqli數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • 淺談PHP性能優(yōu)化之php.ini配置
  • 詳解PHP優(yōu)化巨量關(guān)鍵詞的匹配
  • PHP引擎php.ini參數(shù)優(yōu)化深入講解
  • php優(yōu)化查詢(xún)foreach代碼實(shí)例講解
  • PHP安全配置優(yōu)化詳解
  • PHP內(nèi)存溢出優(yōu)化代碼詳解
  • PHP優(yōu)化教程之解決嵌套問(wèn)題
  • PHP解決高并發(fā)的優(yōu)化方案實(shí)例
  • 如何使用PHP對(duì)象POPO來(lái)優(yōu)化你的代碼

標(biāo)簽:蚌埠 廣元 衢州 大理 萍鄉(xiāng) 棗莊 衡水 江蘇

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP優(yōu)化之批量操作MySQL實(shí)例分析》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話(huà)咨詢(xún)

    • 400-1100-266
    昭苏县| 潜江市| 越西县| 木兰县| 新巴尔虎左旗| 新宾| 武定县| 洱源县| 临沧市| 东兰县| 九龙坡区| 浦东新区| 铁力市| 集贤县| 苏州市| 固原市| 太仆寺旗| 大埔县| 灵寿县| 西乌珠穆沁旗| 剑川县| 永春县| 潞西市| 和林格尔县| 富源县| 陆良县| 栾城县| 武安市| 昭通市| 黔江区| 长垣县| 夏邑县| 连江县| 车致| 大足县| 庐江县| 石柱| 漳州市| 那坡县| 哈巴河县| 铜陵市|