Comment insérer efficacement plusieurs lignes à l'aide d'instructions préparées dans MySQLi ?

Susan Sarandon
Libérer: 2024-10-20 16:30:29
original
915 Les gens l'ont consulté

How to Insert Multiple Rows Efficiently Using Prepared Statements in MySQLi?

Insertion efficace de plusieurs lignes à l'aide d'instructions préparées dans MySQLi

Question :

Comment insérer efficacement plusieurs lignes de données dans une base de données MySQL à l'aide d'une seule instruction préparée ?

Réponse :

Pour obtenir des performances optimales lors de l'insertion de plusieurs lignes, envisagez l'approche suivante :

À l'aide d'une instruction préparée, construisez une requête avec un nombre dynamique d'espaces réservés, correspondant au nombre de colonnes à insérer pour chaque ligne. Aplatissez et décompressez la charge utile des valeurs à l'aide de array_merge(...$rows) pour remplir les espaces réservés.

Exemple de code :

<code class="php">$rows = [[1, 2, 3], [4, 5, 6], [7, 8, 9]];
$rowCount = count($rows);
$values = "VALUES (" . implode('),(', array_fill(0, $rowCount, '?,?,?')) . ")";

$conn = new mysqli("localhost", "root", "", "myDB");
$stmt = $conn->prepare("INSERT INTO test (col1, col2, col3) $values");
$stmt->bind_param(str_repeat('i', $rowCount * 3), ...array_merge(...$rows));
$stmt->execute();</code>
Copier après la connexion

Notez que cette approche suppose un nombre fixe de colonnes à insérer pour chaque ligne.

Approche alternative :

Vous pouvez également utiliser une instruction préparée avec une seule ligne d'espaces réservés et exécuter l'instruction interroger plusieurs fois dans une boucle. Cette méthode est également efficace, bien que potentiellement moins performante pour un grand nombre de lignes.

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!

source:php
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!