「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > PHP および PDO のプリペアド ステートメントを使用して、配列から MySQL に複数のデータ ポイントを効率的に挿入するにはどうすればよいですか?

PHP および PDO のプリペアド ステートメントを使用して、配列から MySQL に複数のデータ ポイントを効率的に挿入するにはどうすればよいですか?

2024 年 11 月 12 日に公開
ブラウズ:926

How Can I Efficiently Insert Multiple Data Points from an Array into MySQL Using Prepared Statements in PHP & PDO?

PHP および PDO でプリペアド ステートメントを使用して MySQL に複数のデータを挿入する

オンライン登録などのシナリオでは、ユーザーは購入、登録、または購入したい複数のアイテムを選択することがよくあります。参加する。これらの項目は通常、処理を容易にするために配列に格納されます。ただし、PHP および PDO でプリペアド ステートメントを使用して配列から MySQL データベースにデータを挿入するのは困難な場合があります。この記事では、この課題を克服する方法を検討します。

1 つのアプローチは、次に示すように、for ループを使用して SQL ステートメントの複数のインスタンスを実行することです。

for($j = 0; $j < (count($data)-1); $j  ) {
   $stmt = $db->prepare("INSERT INTO table SET memberID=?, programID=?, date_added=NOW()");
   $stmt->execute(array($memberid, $data[$j]));
}

この方法は比較的単純ですが、大規模なデータセットを扱うときにパフォーマンスの問題が発生します。

より効率的なアプローチは、単一の SQL ステートメントを動的に構築することです。これは、配列を反復処理し、かっこ内のプレースホルダーと値のカンマ区切りのリストを生成することで実現できます。 $insertQuery = 配列(); $insertData = 配列(); foreach ($data as $row) { $insertQuery[] = '(?, ?)'; $insertData[] = $memberid; $insertData[] = $row; } if (!empty($insertQuery)) { $sql .= implode(', ', $insertQuery); $stmt = $db->prepare($sql); $stmt->execute($insertData); }

このメソッドは、個々のデータを効果的に単一のクエリに結合してデータベースに挿入します。これにより、効率的な処理とオーバーヘッドの削減が保証され、大規模なデータセットを使用するシナリオやパフォーマンスの最適化が重要な場合に適しています。
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3