PDOStatement::closeCursor
(PHP 5 >= 5.1.0, PECL pdo >= 0.9.0)
PDOStatement::closeCursor — Ferme le curseur, permettant à la requête d'être de nouveau exécutée
Description
PDOStatement::closeCursor() libère la connexion du serveur, permettant ainsi à d'autres requêtes SQL d'être exécutées, mais quitte la requête, permettant ainsi qu'elle soit de nouveau exécutée.
Cette méthode est utile pour les drivers de base de données qui ne supportent pas l'exécution d'objet PDOStatement lorsqu'un objet PDOStatement exécuté précédemment a encore des lignes non récupérées. Si votre driver de base de données souffre de cette limitation, le problème se manifestera de lui-même dans une erreur en dehors de la séquence.
PDOStatement::closeCursor() est implémenté soit en tant que méthode optionnelle spécifique au pilote, avec un maximum d'efficacité, ou en tant que solution générique si aucune fonction spécifique au pilote n'est installée. Sémantiquement, la fonction générique PDO revient à écrire le code suivant dans votre script PHP :
<?php do { while ($stmt->fetch()) ; if (!$stmt->nextRowset()) break; } while (true); ?>
Valeurs de retour
Cette fonction retourne TRUE
en cas de
succès ou FALSE
si une erreur survient.
Exemples
Exemple #1 Exemple avec PDOStatement::closeCursor()
<?php /* Création d'un objet PDOStatement */ $stmt = $dbh->prepare('SELECT foo FROM bar'); /* Création d'un second objet PDOStatement */ $otherStmt = $dbh->prepare('SELECT foobaz FROM foobar'); /* Exécute la première requête */ $stmt->execute(); /* Récupération de la première ligne uniquement depuis le résultat */ $stmt->fetch(); /* L'appel suivant à closeCursor() peut être requis par quelques drivers */ $stmt->closeCursor(); /* Maintenant, nous pouvons exécuter la deuxième requête */ $otherStmt->execute(); ?>