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 ?

Comment réinitialiser le pointeur de tableau dans les jeux de résultats PDO pour plusieurs itérations ?

Susan Sarandon
Susan Sarandonoriginal
2024-12-01 22:10:12342parcourir

How to Reset the Array Pointer in PDO Result Sets for Multiple Iterations?

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!

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