Maison  >  Article  >  développement back-end  >  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
DDDoriginal
2024-11-02 08:15:03491parcourir

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>

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>

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>

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