婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP使用PDO從mysql讀取大量數據處理詳解

PHP使用PDO從mysql讀取大量數據處理詳解

熱門標簽:江蘇外呼電銷機器人報價 400電話申請方法收費 400電話辦理福州市 離石地圖標注 電話機器人危險嗎 專業電話機器人批發商 長沙crm外呼系統業務 深圳外呼系統收費 南寧高頻外呼回撥系統哪家好

前言

本文主要介紹了關于PHP利用PDO從mysql讀取大量數據處理的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。

環境

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

適用場景

需要處理一定數據集業務

  • 從mysql讀取一定數據的業務導出
  • 一次需要處理一定的mysql業務操作更新刪除等
  • 更多需要處理一定數據集的操作

pdo 關鍵設置

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

生成器

生成器,迭代數據操作

本生成器可省略

嘗試代碼

class Test {
 public function test()
 {
  set_time_limit(0);
  $dbms='mysql';  //數據庫類型
  $host=C('DB_HOST'); //數據庫主機名
  $dbName=C('DB_NAME'); //使用的數據庫
  $user=C('DB_USER');  //數據庫連接用戶名
  $pass=C('DB_PWD');   //對應的密碼
  $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 "消耗內存:" . (memory_get_usage() / 1024 / 1024) . "M" . $newLine;
  echo "處理數據行數:" . $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
消耗內存:"0.34918212890625M
處理數據行數:254062
success

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

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

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

巨人網絡通訊聲明:本文標題《PHP使用PDO從mysql讀取大量數據處理詳解》,本文關鍵詞  PHP,使用,PDO,從,mysql,讀取,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP使用PDO從mysql讀取大量數據處理詳解》相關的同類信息!
  • 本頁收集關于PHP使用PDO從mysql讀取大量數據處理詳解的相關信息資訊供網民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章
    主站蜘蛛池模板: 武山县| 城固县| 北辰区| 吉林市| 旬邑县| 奇台县| 柏乡县| 泗阳县| 奉化市| 庆城县| 嘉定区| 兴文县| 桐柏县| 井冈山市| 长岛县| 上犹县| 五大连池市| 稷山县| 安岳县| 南靖县| 清流县| 奇台县| 青龙| 武川县| 嘉祥县| 章丘市| 新乐市| 玉门市| 土默特右旗| 屏东县| 来凤县| 池州市| 渝中区| 庆城县| 察雅县| 阿尔山市| 百色市| 图木舒克市| 集安市| 孝昌县| 嘉义市|