好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PHP優化之批量操作MySQL實例分析

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

熱門標簽:邢臺400電話辦理 南京3D地圖標注 南寧電話外呼系統線路 重慶外呼電銷系統多少錢 咸陽電銷 正規電銷機器人系統 辦理400電話哪家好點 濟源百應電銷機器人聯系方式 嘟嘟云外呼系統

本文實例講述了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性能優化之php.ini配置
  • 詳解PHP優化巨量關鍵詞的匹配
  • PHP引擎php.ini參數優化深入講解
  • php優化查詢foreach代碼實例講解
  • PHP安全配置優化詳解
  • PHP內存溢出優化代碼詳解
  • PHP優化教程之解決嵌套問題
  • PHP解決高并發的優化方案實例
  • 如何使用PHP對象POPO來優化你的代碼

標簽:南通 唐山 河南 平頂山 武漢 通遼 黃山 隴南

巨人網絡通訊聲明:本文標題《PHP優化之批量操作MySQL實例分析》,本文關鍵詞  PHP,優化,之,批量,操作,MySQL,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP優化之批量操作MySQL實例分析》相關的同類信息!
  • 本頁收集關于PHP優化之批量操作MySQL實例分析的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 妞妞成人影视在线播放网站| yellow完整版| 男人添女人下面好爽视频| 免费看少妇高潮成人片| 996久久国产精品线观看| 大港区| 舔花缝| 91精品国产综合久久蜜芽解析速度| 美女尿口照片| 青青草国产免费国产| 女女同恋のレズビアンBD下载| 调教成熟美妇肉便奴| 格雷的五十度灰| AA爱做片免费| 极品少妇?开粉嫩小泬| 国产欧美日韩综合二区三区| 公与熄bd曰本中文字幕| 妙龄永久免费网站| 被室友开菊总被室友玩屁股| 午夜精品一区二区三区可下载| 欧美交换配乱吟粗大| 52AV成人久久国产一区| 久久亚洲国产精品五月天 | 老鸭窝91久久久久精品色| 人妻亂伦中文字幕| 体育男生吃武警大雕video| 午夜视频试看| 一级特黄欧美| 欧美办公室系列| 韩国无删减漫画| 2020国产精品视频| 色婷婷国产精品秘?免| 国产成人精品久久亚洲高清不卡 | 国产农村妇女一区二区A片| 日日摸夜夜添夜夜免费视| 国产精品主播在线| 白丝榨精小说h| 欧美国产亚洲精品a第一页| 日本特黄特色大片免费视频在线播放 | 要灬要灬再深点灬受不了视频| 99精品热线在线观看免费视频|