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!