>백엔드 개발 >PHP 튜토리얼 >PDO의 rowCount function_php 기술에 대한 간략한 토론

PDO의 rowCount function_php 기술에 대한 간략한 토론

WBOY
WBOY원래의
2016-05-16 20:13:411005검색

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("SELECT count(*) from db;") $rows = $q->fetch();

분명히 두 번째 방법이 더 효율적입니다

위 내용은 이 글의 전체 내용입니다. 모두 마음에 드셨으면 좋겠습니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.