Trouver une alternative pour mysql_num_rows avec PDO
Dans le but de faire la transition des fichiers PHP vers l'utilisation de PDO, les développeurs peuvent être confrontés à un dilemme concernant l'alternative à la fonction obsolète mysql_num_rows. À l'origine, en utilisant mysql_num_rows, il était possible de compter les lignes renvoyées par une requête MySQL et d'effectuer des actions conditionnelles.
Équivalent PDO pour compter les lignes
L'équivalent PDO pour compter les lignes consiste à utiliser la méthode fetchColumn(). Cette méthode peut être utilisée conjointement avec une instruction query() ou préparer() et exécuter().
Utilisation de query() et fetchColumn()
<code class="php">$res = $DB->query('SELECT COUNT(*) FROM table'); $num_rows = $res->fetchColumn();</code>
Utilisation de préparer(), exécuter() et fetchColumn()
<code class="php">$res = $DB->prepare('SELECT COUNT(*) FROM table'); $res->execute(); $num_rows = $res->fetchColumn();</code>
Instructions conditionnelles avec fetchColumn()
Le fetchColumn( ) peut également être utilisée pour déterminer conditionnellement si des données existent ou ont été sélectionnées :
<code class="php">$res = $DB->query('SELECT COUNT(*) FROM table'); $data_exists = ($res->fetchColumn() > 0) ? true : false;</code>
Incorporation de variables conditionnelles
En incorporant des variables, vous pouvez directement attribuer la résultat d'une vérification du nombre de lignes :
<code class="php">$res = $DB->query('SELECT COUNT(*) FROM table'); $message = ($res->fetchColumn() > 0) ? array('status' => 'ok') : array('status' => 'error');</code>
En utilisant la méthode PDO fetchColumn(), les développeurs peuvent remplacer efficacement la fonctionnalité de mysql_num_rows dans leurs scripts PHP lors de la transition vers PDO pour les opérations de base de données. Cela garantit la compatibilité avec les environnements PHP modernes et les meilleures pratiques pour les interactions avec les bases de données.
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!