Maison >développement back-end >tutoriel php >Comment récupérer plusieurs ensembles de résultats à partir de procédures stockées dans MySQL avec PHP/mysqli et PDO ?
Gérer plusieurs ensembles de résultats à partir de procédures stockées dans MySQL à l'aide de PHP/mysqli
Récupérer plusieurs ensembles de résultats à partir de procédures stockées dans PHP/mysqli peut être obtenu en utilisant la fonction mysqli_stmt_next_result(). L'exemple suivant montre comment utiliser cette fonction pour passer au deuxième ensemble de résultats :
<code class="php">$stmt = mysqli_prepare($db, 'CALL multiples(?, ?)'); mysqli_stmt_bind_param($stmt, 'ii', $param1, $param2); mysqli_stmt_execute($stmt); // Fetch and process the first result set $result1 = mysqli_stmt_get_result($stmt); while ($row1 = mysqli_fetch_assoc($result1)) { // Process row1 } // Advance to the second result set mysqli_stmt_next_result($stmt); if (mysqli_stmt_error($stmt)) { die('Failed to advance to the second result set: ' . mysqli_stmt_error($stmt)); } // Fetch and process the second result set $result2 = mysqli_stmt_get_result($stmt); while ($row2 = mysqli_fetch_assoc($result2)) { // Process row2 }</code>
Solution PDO
En utilisant PDO, le code apparaîtrait comme suit :
<code class="php">$stmt = $db->prepare('CALL multiples(:param1, :param2)'); $stmt->execute([':param1' => $param1, ':param2' => $param2]); // Fetch and process the first result set while ($row1 = $stmt->fetch()) { // Process row1 } // Advance to the second result set $stmt->nextRowset(); // Fetch and process the second result set while ($row2 = $stmt->fetch()) { // Process row2 }</code>
Remarque :
Il est important de se rappeler que tous les serveurs de bases de données ne prennent pas en charge plusieurs ensembles de résultats à partir de procédures stockées. Référez-vous toujours à la documentation de votre serveur de base de données pour connaître la compatibilité.
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!