Maison >base de données >tutoriel mysql >Comment insérer plusieurs lignes dans une base de données MySQL à l'aide de PDO dans une seule requête ?

Comment insérer plusieurs lignes dans une base de données MySQL à l'aide de PDO dans une seule requête ?

Barbara Streisand
Barbara Streisandoriginal
2024-11-07 04:15:03880parcourir

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

PDO MySQL : insérer plusieurs lignes dans une requête

L'insertion de plusieurs lignes dans une base de données MySQL à l'aide de PDO peut être réalisée en construisant soigneusement un seul requête. L'approche courante consistant à préparer une requête avec des espaces réservés, puis à lier les valeurs en boucle dans le tableau de données ne fonctionne pas avec plusieurs insertions.

Pour surmonter cette limitation, nous pouvons créer une longue requête contenant toutes les valeurs et tous les espaces réservés nécessaires. . Voici un exemple :

$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();

Dans cet exemple, le tableau $data contient les valeurs de chaque ligne. Nous parcourons le tableau et lions chaque valeur à un espace réservé avec un index spécifique. Cela garantit que les valeurs sont correctement ordonnées et insérées dans la base de données.

En préparant une seule requête et en liant les valeurs de cette manière, nous pouvons insérer efficacement plusieurs lignes dans une table MySQL à l'aide de PDO.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn