Plusieurs instructions INSERT MySQL dans une seule requête utilisant PHP
En PHP, il est possible d'exécuter plusieurs instructions INSERT dans une seule requête en utilisant la syntaxe suivante :
<code class="php">$string1 = "INSERT INTO table1 (column1, column2) VALUES (value1, value2);\n"; $string1 .= "INSERT INTO table2 (column1, column2) VALUES (value3, value4);\n"; $string1 .= "INSERT INTO table3 (column1, column2) VALUES (value5, value6);"; mysql_query($string1) or die(mysql_error());</code>
Cependant, cette approche n'est généralement pas recommandée pour plusieurs raisons :
Approche optimisée
Une meilleure approche pour insérer plusieurs lignes consiste à utiliser plusieurs instructions INSERT avec la syntaxe suivante :
<code class="php">$sql = "INSERT INTO table1 (column1, column2) VALUES "; for ($i = 0; $i < count($values); $i++) { $sql .= "($values[$i][0], $values[$i][1])"; if ($i < count($values) - 1) { $sql .= ", "; } } mysql_query($sql) or die(mysql_error());</code>
En utilisant cette approche, chaque ligne est insérée séparément, offrant une meilleure intégrité des données et une meilleure prise en charge des transactions. De plus, la base de données peut optimiser chaque déclaration individuellement, améliorant potentiellement l'efficacité.
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!