PHP データベースで大規模な結果セットを扱う場合、開発者はどちらを使用するかを選択する必要があるかもしれません。ループ内の PDO::fetchAll() と PDO::fetch()。この決定は主にパフォーマンスとメモリを考慮して行われます。
PDO::fetchAll()
PDO::fetch()
パフォーマンスの比較
ベンチマークは、PDO が::fetchAll() は、特に大きな結果セットの場合、ループ内で PDO::fetch() より高速です。ただし、このパフォーマンス上の利点には、大幅に多くのメモリを消費するという代償が伴います。
メモリに関する考慮事項
PDO::fetchAll() のメモリ要件はサイズに比例します。結果セットの。大規模なデータセットの場合、これによりメモリの枯渇やパフォーマンスの問題が発生する可能性があります。一方、PDO::fetch() は、行を順番に処理するため、大量のメモリを必要としません。
選択に影響を与える要素
次の間の適切な選択PDO::fetchAll() と PDO::fetch() は依存しますon:
例:
トレードオフを説明するために、次のベンチマークを考慮してください。コード:
$dbh = new PDO(...); $sql = 'SELECT * FROM test_table'; $stmt = $dbh->query($sql); $start_all = microtime(true); $data = $stmt->fetchAll(); $end_all = microtime(true); $start_one = microtime(true); while($data = $stmt->fetch()) {} $end_one = microtime(true); echo 'Result : ' . PHP_EOL; echo 'fetchAll : ' . ($end_all - $start_all) . 's, ' . memory_get_usage() . 'b' . PHP_EOL; echo 'fetch : ' . ($end_one - $start_one) . 's, ' . memory_get_usage() . 'b' . PHP_EOL;
fetchAll メソッドは 0.35 秒かかり、100MB のメモリを必要としますが、フェッチ ループは 0.39 秒かかり、メモリの消費量はわずか 440 バイトです。
以上がPHP で大きな結果セットを扱う場合: PDO::fetchAll または PDO::fetch を使用する必要がありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。