ホームページ  >  記事  >  バックエンド開発  >  PHP が PDO を使用して mysql を操作してデータを読み取る手順の詳細な説明

PHP が PDO を使用して mysql を操作してデータを読み取る手順の詳細な説明

php中世界最好的语言
php中世界最好的语言オリジナル
2018-05-17 14:58:562369ブラウズ

今回は、PHP を使用して mysql を操作してデータを読み取る手順について詳しく説明します。PHP が PDO を使用して mysql を操作してデータを読み取るための 注意事項 は何ですか? 以下は実際的なケースです。一見。

はじめに

この記事では主に、PDO を使用して mysql から大量のデータを読み取るための PHP に関する関連内容を紹介します。以下では多くを述べませんが、参照してください。詳しい紹介にて。

環境

  • 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 == &#39;cli&#39; ? "\n" : &#39;<br />&#39;;
  foreach ($this->cursor($sth) as $row) {
//   var_dump($row);
   echo $row[&#39;id&#39;] . $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 中国語 Web サイトの他の関連記事に注目してください。

推奨読書:

ThinkPHPデータベース接続操作事例分析

PHP7.1にyaf拡張機能をインストールする手順の詳細な説明

以上がPHP が PDO を使用して mysql を操作してデータを読み取る手順の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。