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
Libérer: 2024-10-30 19:30:02
original
834 Les gens l'ont consulté

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>
Copier après la connexion

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>
Copier après la connexion

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!

source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal