ホームページ  >  記事  >  バックエンド開発  >  PHP で大量のデータをループするときにメモリが枯渇する問題を解決する方法、php枯渇_PHP チュートリアル

PHP で大量のデータをループするときにメモリが枯渇する問題を解決する方法、php枯渇_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-12 09:07:37909ブラウズ

PHPで大量のデータをループするときにメモリが枯渇し、PHPが枯渇する問題を解決する方法

私は最近、PHPプログラムを開発しているときに次の問題に遭遇しました:

PHP 致命的エラー: 許可されたメモリ サイズ 268 435 456 バイトが使い果たされました

エラー メッセージは、最大許容メモリが使い果たされたことを示しています。最初はこのようなエラーが発生したことに驚きましたが、よく考えてみると、私が開発しているプログラムは foreach ループ ステートメントを使用して 40,000 レコードのデータを持つテーブル内の特定の特性を検索することになっているため、驚くべきことではありません。つまり、一度に4万件のデータを取り出し、毎日のデータを1つずつチェックする必要があります。 40,000 個のデータがすべてメモリに読み込まれていると考えられます。メモリがバーストしないのは不思議です。

結局、何年もプログラミングをしてきたので、PHP が提供する API はデータを一度にロードせず、ストリーミング メディアのように使用して失われる可能性があり、データが蓄積されないことを漠然と覚えています。想い出。簡単に検索したところ、公式Webサイトに正しい使用方法が見つかりました。

この問題は、PHP の公式 Web サイトでは「バッファー付きクエリ」と「バッファーなしクエリ」と呼ばれています。 PHP のデフォルトのクエリ モードはバッファ モードです。つまり、クエリ データの結果は、PHP プログラムによる処理のために一度にメモリに抽出されます。これにより、PHP プログラムに行数のカウント、特定の行へのポインタの指示などの追加機能が与えられます。さらに重要なことは、プログラムがデータ セットに対して二次クエリとフィルタリング操作を繰り返し実行できることです。ただし、このバッファー クエリ モードの欠点は、メモリを消費すること、つまり、速度と引き換えにスペースを消費することです。

対照的に、別の PHP クエリ モードはバッファなしクエリであり、データベース サーバーはデータを一度に返すのではなく 1 つずつ返します。その結果、PHP プログラムが消費するメモリは少なくなりますが、データベース サーバーへの負荷は増大します。すべてのデータがフェッチされるまで、データベースは PHP がデータをフェッチするのを待機するためです。

明らかに、バッファー クエリ モードは少量のデータ量のクエリに適しており、非バッファー クエリは大量のデータ量のクエリに適しています。

PHP のバッファー モード クエリについては誰もが知っています。以下に示す例は、非バッファー クエリ API を実行する方法です。

非バッファークエリメソッド 1: mysqli

リーリー

非バッファークエリメソッド 2: pdo_mysql

リーリー

非バッファークエリメソッド 3: mysql

リーリー

上記の内容は、PHPで大量のデータを循環させた際のメモリ不足の問題を解決するためにエディターが共有した方法です。皆様のお役に立てれば幸いです。

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/1060103.html技術記事 PHP で大量のデータをループするときにメモリが枯渇する問題を解決する方法 最近、PHP プログラムを開発しているときに次の問題に遭遇しました: PHP 致命的なエラー: 許容メモリ サイズ 268 435 4...
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。