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 ?

Comment récupérer plusieurs ensembles de résultats à partir de procédures stockées dans MySQL avec PHP/mysqli et PDO ?

DDD
DDDoriginal
2024-10-30 19:30:02798parcourir

How to Retrieve Multiple Result Sets from Stored Procedures in MySQL with PHP/mysqli and 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!

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