PDO でプリペアド ステートメントを使用した複数の行の挿入
データベースにデータを効率的に挿入することは、特に大規模なデータセットを扱う場合に重要です。この質問では、挿入プロセスを最適化するために、PHP の PDO 拡張機能で単一のプリペアド ステートメントを使用して複数の行を挿入する可能性を検討します。
問題:
次の必要性が生じます。配列からの動的データを使用してテーブルに複数の行を挿入します。 PDO を使用して単一の行を挿入する一般的なアプローチを示します:
$params = [ ':val1' => 'val1', ':val2' => 'val2', ':val3' => 'val3', ]; $sql = "INSERT INTO table VALUES (col1, col2, col3) VALUES (:val1, :val2, :val3)"; $stmt = DB::getInstance()->prepare($sql); $stmt->execute($params);
答え:
単一の準備されたステートメントで複数の行を挿入するには、次のことが可能です。複数の値を含む単一の INSERT クエリを構築します。セキュリティと柔軟性を確保するために、パラメーターは個別に渡されます。
例:
挿入する行の配列が指定された場合:
$rows = [ ['abc', 'def', 'ghi'], ['abc', 'def', 'ghi'], ['abc', 'def', 'ghi'], ];
次のコードは、各行のプレースホルダーを含む準備済みクエリを作成します。
$row_length = count($rows[0]); $nb_rows = count($rows); $length = $nb_rows * $row_length; $args = implode(',', array_map( function($el) { return '('.implode(',', $el).')'; }, array_chunk(array_fill(0, $length, '?'), $row_length) )); $params = array(); foreach ($rows as $row) { foreach ($row as $value) { $params[] = $value; } } $query = "INSERT INTO Table (col1, col2, col3) VALUES " . $args; $stmt = DB::getInstance()->prepare($query); $stmt->execute($params);
各行の値はパラメーターとして個別に渡されるため、セキュリティが維持され、複数の行を効率的に挿入できます。
以上が単一のプリペアド ステートメントを使用して PDO に複数の行を挿入できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。