PDO プリペアド ステートメント Fetch() の結果が重複するのはなぜですか?

Barbara Streisand
リリース: 2024-11-01 20:47:30
オリジナル
347 人が閲覧しました

Why is my PDO Prepared Statement Fetch() Duplicating Results?

PDO プリペアド ステートメント Fetch() 結果の複製

問題

PDO プリペアド ステートメントと fetch() を使用する PHP スクリプト重複したデータをCSVファイルに出力しています。データベースの各行が 2 回エコーされ、その結果、列の値が 2 倍になります。

分析

以前は、PDO を使用しない場合、クエリは期待どおりに機能していました。したがって、問題は fetch() の使用法にある可能性があります。

解決策

fetch() を呼び出すときに目的のデータ取得モードを指定することで、結果の重複の問題を解決できます。 2 つのオプションがあります:

  • PDO::FETCH_ASSOC: 列名によってインデックス付けされた配列を返します。
  • PDO::FETCH_NUM: 列によってインデックス付けされた配列を返します

これを実装するには、コードを次のように変更します。

<code class="php">while ($rows_get_rows = $result_get_rows->fetch(PDO::FETCH_ASSOC)) {
  $csv .= '"'.join('","', str_replace('"', '""', $rows_get_rows))."\"\n";
}</code>
ログイン後にコピー

以上がPDO プリペアド ステートメント Fetch() の結果が重複するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート