欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

PHP優(yōu)化之如何批量操作MySQL-創(chuàng)新互聯(lián)

這篇文章主要介紹“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)主機(jī)托管與主機(jī)租用業(yè)務(wù);數(shù)據(jù)中心含:雙線機(jī)房,BGP機(jī)房,電信機(jī)房,移動機(jī)房,聯(lián)通機(jī)房。

設(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ù)。

先來看看下面這一段代碼:

<?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)過測試,上面代碼運行結(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';

上面這段代碼的運行結(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://aaarwkj.com/article10/gidgo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化商城網(wǎng)站、Google、靜態(tài)網(wǎng)站、建站公司、ChatGPT

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
欧美人与性一区二区三区| 日韩电影在线播放中文字幕| 色综合色狠狠天天综合色| 国产成人av综合久久视色| 欧美日韩免费爱爱视频| 婷婷丁香久久五月婷婷| 国产中文字幕一区久久| 欧美日本国产老熟女视频| 亚洲一区麻豆文化传媒| 国产有码日产一区在线观看| 精精国产xxxx视频在线不卡| 亚洲一区二区日韩在线| 久久婷婷精品国产亚洲av| 国产精品久久一区二区三区蜜桃| 午夜福利一区二区在线| 欧美熟妇精品一级视频| 丰满人妻被猛烈进入中| 人妻中文字幕一区二区三| 深夜成人免费观看视频| 91午夜福利视频在线观看| 久久99精品国产99久久无| 欧美日韩一区中文字幕| 日本在线有码中文视频| 日本高清免费观看一区| 美女露脸口爆吞精视频| 国产欧美日本综合一区| 国产亚洲综合区成人国产| 人妻在线中文字幕一区| 亚洲综合av一区二区三区四区 | 国产区精品福利在线熟女| 精品亚洲天堂一区二区三区| 国产av高清亚洲精品高清二部| 日韩精品福利片午夜免费| 国产午夜福利av在线麻豆| 亚洲天堂av成人在线观看| 九色综合狠狠综合久久| 亚洲成人av网址大全| 特级特色生活片免费看| 成人性生交大片免费看中文 | 蜜桃av在线观看一区二区| 中出亚洲精品日韩在线视频|