PDO에는 이전 SQL 문의 영향을 받은 행 수를 반환하는 PDOStatement::rowCount 함수가 있습니다.
rowCount 함수의 결과는 DELETE, INSERT, UPDATE 문에서는 정확하지만, select 문에서는 데이터베이스 구현과 관련이 있습니다. 일부 데이터베이스는 select 문을 실행할 때 모든 결과 세트를 메모리로 읽어오지만, 결과 세트 수가 너무 많은 경우 이는 확실히 비효율적입니다. 대부분의 데이터베이스는 결과 집합의 일부만 반환하고 필요할 때 결과 집합의 나머지 부분을 반환하므로 메모리 사용량과 실행 효율성이 모두 최적화됩니다. 후자의 경우 rowCount는 SELECT 문 결과 집합에 올바른 행 수를 반환할 수 없습니다.
SELECT 결과에서 올바른 행 수를 가져오는 방법에는 여러 가지가 있습니다.
1. fetchAll 함수를 사용하세요.
$q = $db->query("SELECT ...");
$rows = $q->fetchAll();
$rowCount = count($rows);
2. SQL 카운트 함수를 사용합니다.
$q = $db->query("db에서 SELECT 개수(*);");
$rows = $q->fetch();
$rowCount = $rows[0];
분명히 두 번째 방법이 더 효율적입니다
위 내용은 관련 내용을 포함하여 PHP PDO 선택문 결과의 행 수 계산을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.