Heim >Datenbank >MySQL-Tutorial >Wie kann man Zeilen aus einer PDO-SELECT-Anweisung in PHP effizient zählen?
So zählen Sie Zeilen in PHP PDO
PDO, die Industriestandardbibliothek für den Zugriff auf Datenbanken in PHP, verfügt nicht über eine dedizierte Methode zum Zählen Von SELECT-Abfragen zurückgegebene Zeilen. Eine übliche Problemumgehung ist die Verwendung von count($results->fetchAll()), aber das ist nicht immer der effizienteste Ansatz.
PDOStatement::rowCount
The Das PDO-Anweisungsobjekt stellt eine rowCount-Methode bereit. Allerdings heißt es in der offiziellen PDO-Dokumentation:
For most databases, PDOStatement::rowCount() does not return the number of rows affected by a SELECT statement. Instead, use PDO::query() to issue a SELECT COUNT(*) statement with the same predicates as your intended SELECT statement, then use PDOStatement::fetchColumn() to retrieve the number of rows that will be returned. Your application can then perform the correct action.
Zeilen mit vorhandenem Recordset zählen
Wenn Sie die Daten bereits abgerufen haben, können Sie die Zählfunktion verwenden das Ergebnisarray:
$stmt = $db->prepare('SELECT * FROM table'); $stmt->execute(); $rowCount = count($stmt->fetchAll(PDO::FETCH_ASSOC));
Alternativ können Sie sich auf die objektorientierte Durchquerung verlassen und die Zeilen manuell zählen:
$rowCount = 0; while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) { $rowCount++; }
Bedenken Sie, dass das Abrufen aller Zeilen in den Speicher die Anwendungsleistung beeinträchtigen kann. insbesondere bei großen Ergebnismengen. Erwägen Sie bei Bedarf die Paginierung oder andere Optimierungstechniken.
Das obige ist der detaillierte Inhalt vonWie kann man Zeilen aus einer PDO-SELECT-Anweisung in PHP effizient zählen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!