La requête MySQL ne renvoie qu'une seule ligne : débogage et résolution
Lorsque vous travaillez avec MySQL, vous rencontrez des cas où un script PHP ne récupère qu'une seule ligne peut être déroutant. Ce problème survient lorsque la requête elle-même est valide, mais que l'implémentation du script l'empêche de récupérer toutes les lignes attendues.
Dépannage du problème
Considérez le code PHP fourni, qui exécute une requête pour récupérer les lignes de la table fastsearch :
$query = mysql_query("SELECT `title`, `url_title` FROM `fastsearch` WHERE `tags` LIKE '%$q%' LIMIT 5"); $query2 = mysql_fetch_assoc($quer); print_r($query2);
Bien que la requête SQL renvoie plusieurs lignes, le script affiche une seule ligne. Ce comportement se produit car mysql_fetch_assoc() ne récupère qu'une seule ligne par défaut. Pour récupérer toutes les lignes, nous devons les parcourir à l'aide d'une boucle.
Solution : utiliser la boucle while pour récupérer plusieurs lignes
L'extrait de code corrigé utiliserait un boucle while pour parcourir les résultats de la requête et imprimer chaque ligne :
$query = mysql_query("SELECT `title`, `url_title` FROM `fastsearch` WHERE `tags` LIKE '%$q%' LIMIT 5"); while ($row = mysql_fetch_assoc($query)) { print_r($row); }
Dans ce code mis à jour, mysql_fetch_assoc() est appelé dans la boucle et la variable $row se voit attribuer la ligne actuelle. Cela permet à la boucle de parcourir chaque ligne dans les résultats de la requête, permettant ainsi l'impression de toutes les lignes.
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!