Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Memasukkan Berbilang Baris ke dalam Pangkalan Data MySQL menggunakan PDO dalam Satu Pertanyaan?

Bagaimana untuk Memasukkan Berbilang Baris ke dalam Pangkalan Data MySQL menggunakan PDO dalam Satu Pertanyaan?

Barbara Streisand
Barbara Streisandasal
2024-11-07 04:15:03891semak imbas

How to Insert Multiple Rows into a MySQL Database using PDO in a Single Query?

PDO MySQL: Masukkan Berbilang Baris dalam Satu Pertanyaan

Memasukkan berbilang baris ke dalam pangkalan data MySQL menggunakan PDO boleh dicapai dengan membina satu pertanyaan dengan teliti pertanyaan. Pendekatan biasa untuk menyediakan pertanyaan dengan ruang letak dan kemudian mengikat nilai gelung melalui tatasusunan data tidak berfungsi dengan berbilang sisipan.

Untuk mengatasi had ini, kami boleh membuat pertanyaan panjang yang mengandungi semua nilai dan ruang letak yang diperlukan . Berikut ialah contoh:

$query = "INSERT INTO $table (key1, key2, key3, etc) VALUES (:key1, :key2, :key3, etc), (:key1, :key2, :key3, etc), (:key1, :key2, :key3, etc)";

$dbh = new PDO(...);
$stmt = $dbh->prepare($query);

$i = 1;
$data = [[], ...]; // Assuming $data contains the rows to be inserted

foreach($data as $row) {
    foreach ($row as $key => $value) {
        $stmt->bindValue($i++, $value);
    }
}

$stmt->execute();

Dalam contoh ini, tatasusunan $data mengandungi nilai setiap baris. Kami gelung melalui tatasusunan dan mengikat setiap nilai pada pemegang tempat dengan indeks tertentu. Ini memastikan bahawa nilai disusun dengan betul dan dimasukkan ke dalam pangkalan data.

Dengan menyediakan satu pertanyaan dan mengikat nilai dengan cara ini, kami boleh memasukkan berbilang baris dengan cekap ke dalam jadual MySQL menggunakan PDO.

Atas ialah kandungan terperinci Bagaimana untuk Memasukkan Berbilang Baris ke dalam Pangkalan Data MySQL menggunakan PDO dalam Satu Pertanyaan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn