濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > PHP使用PDO從mysql讀取大量數(shù)據(jù)處理詳解

PHP使用PDO從mysql讀取大量數(shù)據(jù)處理詳解

熱門標(biāo)簽:江蘇外呼電銷機(jī)器人報(bào)價(jià) 400電話申請(qǐng)方法收費(fèi) 400電話辦理福州市 離石地圖標(biāo)注 電話機(jī)器人危險(xiǎn)嗎 專業(yè)電話機(jī)器人批發(fā)商 長沙crm外呼系統(tǒng)業(yè)務(wù) 深圳外呼系統(tǒng)收費(fèi) 南寧高頻外呼回?fù)芟到y(tǒng)哪家好

前言

本文主要介紹了關(guān)于PHP利用PDO從mysql讀取大量數(shù)據(jù)處理的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹吧。

環(huán)境

  • mysql: 5.6.34
  • php: 5.6
  • nginx: php-fpm

適用場景

需要處理一定數(shù)據(jù)集業(yè)務(wù)

  • 從mysql讀取一定數(shù)據(jù)的業(yè)務(wù)導(dǎo)出
  • 一次需要處理一定的mysql業(yè)務(wù)操作更新刪除等
  • 更多需要處理一定數(shù)據(jù)集的操作

pdo 關(guān)鍵設(shè)置

$dbh = new \PDO($dsn, $user, $pass);
# 關(guān)鍵設(shè)置,如果不設(shè)置,php依舊會(huì)從pdo一次取出數(shù)據(jù)到php
$dbh->setAttribute(\PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, false);
//perpare里的游標(biāo)屬性不是必須的
$sth = $dbh->prepare("SELECT * FROM `order`", array(\PDO::ATTR_CURSOR => \PDO::CURSOR_SCROLL));
$sth->execute();

生成器

生成器,迭代數(shù)據(jù)操作

本生成器可省略

嘗試代碼

class Test {
 public function test()
 {
  set_time_limit(0);
  $dbms='mysql';  //數(shù)據(jù)庫類型
  $host=C('DB_HOST'); //數(shù)據(jù)庫主機(jī)名
  $dbName=C('DB_NAME'); //使用的數(shù)據(jù)庫
  $user=C('DB_USER');  //數(shù)據(jù)庫連接用戶名
  $pass=C('DB_PWD');   //對(duì)應(yīng)的密碼
  $dsn="$dbms:host=$host;dbname=$dbName";
  $dbh = new \PDO($dsn, $user, $pass);
  $dbh->setAttribute(\PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, false);
  $sth = $dbh->prepare("SELECT * FROM `order`");
  $sth->execute();
  $i = 0;

  $newLine = PHP_SAPI == 'cli' ? "\n" : 'br />';

  foreach ($this->cursor($sth) as $row) {
//   var_dump($row);
   echo $row['id'] . $newLine;
   $i++;
  }

  echo "消耗內(nèi)存:" . (memory_get_usage() / 1024 / 1024) . "M" . $newLine;
  echo "處理數(shù)據(jù)行數(shù):" . $i . $newLine;
  echo "success";
 }

 public function cursor($sth)
 {
  while($row = $sth->fetch(\PDO::FETCH_ASSOC)) {
   yield $row;
  }
 }
}

$test = new Test();
$test->test();

輸出

1
... //省略部分id
804288
消耗內(nèi)存:"0.34918212890625M
處理數(shù)據(jù)行數(shù):254062
success

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • php中mysql連接方式PDO使用詳解
  • Php中用PDO查詢Mysql來避免SQL注入風(fēng)險(xiǎn)的方法
  • php mysql PDO 查詢操作的實(shí)例詳解
  • PHP實(shí)現(xiàn)PDO的mysql數(shù)據(jù)庫操作類
  • php中數(shù)據(jù)庫連接方式pdo和mysqli對(duì)比分析
  • php基于PDO實(shí)現(xiàn)功能強(qiáng)大的MYSQL封裝類實(shí)例
  • php下pdo的mysql事務(wù)處理用法實(shí)例
  • PHP基于pdo的數(shù)據(jù)庫操作類【可支持mysql、sqlserver及oracle】
  • PHP基于PDO擴(kuò)展操作mysql數(shù)據(jù)庫示例
  • PHP使用PDO創(chuàng)建MySQL數(shù)據(jù)庫、表及插入多條數(shù)據(jù)操作示例

標(biāo)簽:株洲 濱州 興安盟 南京 曲靖 太原 白酒營銷 南昌

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP使用PDO從mysql讀取大量數(shù)據(jù)處理詳解》,本文關(guān)鍵詞  PHP,使用,PDO,從,mysql,讀取,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP使用PDO從mysql讀取大量數(shù)據(jù)處理詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP使用PDO從mysql讀取大量數(shù)據(jù)處理詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    福安市| 新津县| 绥宁县| 五原县| 固阳县| 澎湖县| 富源县| 集贤县| 武陟县| 沅江市| 许昌市| 巴楚县| 巢湖市| 南开区| 永修县| 洞口县| 工布江达县| 临清市| 美姑县| 锡林郭勒盟| 六盘水市| 西盟| 平定县| 化隆| 德钦县| 那曲县| 思茅市| 永城市| 杨浦区| 台安县| 山东省| 阳高县| 阳东县| 琼结县| 三门峡市| 外汇| 聊城市| 嘉黎县| 大关县| 承德县| 东光县|