Maison >base de données >tutoriel mysql >Comment réinitialiser le pointeur de tableau dans les jeux de résultats PDO pour plusieurs itérations ?
Réinitialisation du pointeur de tableau dans les résultats PDO
Lors de la transition des méthodes MySQL SELECT vers PDO, la réinitialisation du pointeur de tableau devient essentielle pour parcourir les méthodes récupérées tableaux plusieurs fois. Bien que MySQL propose mysql_data_seek() pour accomplir cela, PDO nécessite une approche différente.
Pour réussir à réinitialiser le pointeur de tableau dans PDO, envisagez la solution suivante :
Tout d'abord, récupérez l'ensemble de résultats dans un tableau en utilisant la méthode fetchAll(). Cette méthode récupère toutes les lignes dans un tableau PHP. Par la suite, vous pouvez parcourir ce tableau plusieurs fois pour accéder et traiter les données de chaque ligne.
Voici un exemple mis à jour :
$pdo = new PDO('mysql:host=' . $host . ';dbname='.$database, $username, $password); $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $stmt = $pdo->prepare('SELECT * FROM mytable WHERE active = 1 ORDER BY name ASC'); $stmt->setFetchMode(PDO::FETCH_ASSOC); $stmt->execute(); $rows = $stmt->fetchAll(); // Saving results into an array // First Iteration foreach ($rows as $r) { // ... } // Second Iteration foreach ($rows as $r) { // ... }
Cette approche révisée vous permet de parcourir le résultat défini plusieurs fois, en commençant à chaque fois par la première ligne.
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!