Maison >base de données >tutoriel mysql >Pourquoi ma requête MySQL en PHP ne renvoie-t-elle qu'une seule ligne ?

Pourquoi ma requête MySQL en PHP ne renvoie-t-elle qu'une seule ligne ?

Barbara Streisand
Barbara Streisandoriginal
2024-12-01 03:54:11821parcourir

Why Does My MySQL Query in PHP Only Return One Row?

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!

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