Maison > développement back-end > tutoriel php > Comment puis-je utiliser `mysqli_fetch_array()` plusieurs fois sur le même ensemble de résultats ?

Comment puis-je utiliser `mysqli_fetch_array()` plusieurs fois sur le même ensemble de résultats ?

DDD
Libérer: 2024-11-02 08:15:03
original
589 Les gens l'ont consulté

How Can I Use `mysqli_fetch_array()` Multiple Times on the Same Resultset?

Utilisation de mysqli_fetch_array() plusieurs fois

Lorsque vous travaillez avec des bases de données utilisant PHP et MySQL, vous pouvez rencontrer une situation dans laquelle vous devez accéder plusieurs fois aux mêmes résultats de requête. en utilisant la fonction mysqli_fetch_array(). Cependant, tenter d'utiliser mysqli_fetch_array() sur le même ensemble de résultats plusieurs fois entraînera une sortie vide.

En effet, mysqli_fetch_array() récupère et avance le pointeur dans l'ensemble de résultats. Ainsi, si vous essayez de récupérer à nouveau le même résultat, il n'y aura plus de données à récupérer.

Pour résoudre ce problème, vous devez séparer la manipulation des données de la sortie. Tout d'abord, récupérez toutes les données de la base de données et stockez-les dans un tableau :

<code class="php">$db_res = mysqli_query($db_link, $sql);
$data = [];
while ($row = mysqli_fetch_assoc($db_res)) {
    $data[] = $row;
}</code>
Copier après la connexion

Remarque : depuis PHP 5.3, vous pouvez utiliser fetch_all() au lieu de la boucle explicite :

<code class="php">$db_res = mysqli_query($db_link, $sql);
$data = $db_res->fetch_all(MYSQLI_ASSOC);</code>
Copier après la connexion

Une fois que vous avez stocké les données dans un tableau, vous pouvez les parcourir autant de fois que nécessaire :

Rangée du haut :

<code class="php">foreach ($data as $row) {</code>
Copier après la connexion

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