ホームページ >データベース >mysql チュートリアル >単一のプリペアド ステートメントを使用して PDO に複数の行を挿入できますか?

単一のプリペアド ステートメントを使用して PDO に複数の行を挿入できますか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-11-06 21:18:02518ブラウズ

Can I Use a Single Prepared Statement to Insert Multiple Rows in PDO?

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。