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!