Maison > développement back-end > tutoriel php > Pourquoi « num_rows » de MySQLi renvoie-t-il 1 lors du comptage des lignes ?

Pourquoi « num_rows » de MySQLi renvoie-t-il 1 lors du comptage des lignes ?

DDD
Libérer: 2024-11-08 09:55:02
original
325 Les gens l'ont consulté

Why Does MySQLi's `num_rows` Return 1 When Counting Rows?

Exposer la faille dans le comptage de lignes de MySQLi

Pour tenter de déterminer le nombre de lignes d'une table, un extrait de code a été implémenté :

$result = $db->query("SELECT COUNT(*) FROM `table`;");
$count = $result->num_rows;
Copier après la connexion

Cependant, la valeur du compteur reste systématiquement à 1, quel que soit le nombre réel de lignes dans la table.

Lors d'un débogage plus approfondi, le problème devient évident : la requête exécutée renvoie un enregistrement unique avec la valeur de comptage stockée dans la première colonne. Par conséquent, pour accéder au résultat, l'enregistrement doit être récupéré :

$result = $db->query("SELECT COUNT(*) FROM `table`");
$row = $result->fetch_row();
echo '#: ', $row[0];
Copier après la connexion

Cette approche garantit le nombre correct de lignes dans la table, même lorsque la requête est exécutée via phpMyAdmin.

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