>백엔드 개발 >PHP 튜토리얼 >PHP에서 PDO를 사용하여 행 개수를 얻는 최적의 접근 방식은 무엇입니까?

PHP에서 PDO를 사용하여 행 개수를 얻는 최적의 접근 방식은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-23 19:39:21387검색

What's the Optimal Approach to Getting a Row Count with PDO in PHP?

PDO를 사용한 행 수: 최적의 접근 방식

PHP에서 PDO를 사용하여 행 수를 가져오는 방법은 다양한 방법으로 얻을 수 있습니다. 그러나 최선의 접근 방식은 특정 사용 사례와 데이터 크기 고려 사항에 따라 다릅니다.

데이터 자체가 아닌 행 개수만 필요한 경우 "SELECT count(*)" 쿼리를 사용하는 것이 좋습니다. 코드 예제는 다음과 같습니다.

$sql = "SELECT count(*) FROM `table` WHERE foo = ?";
$result = $con->prepare($sql);
$result->execute([$bar]);
$number_of_rows = $result->fetchColumn();

검색된 데이터와 함께 행 수가 필요한 시나리오의 경우 PDO는 PDOStatement::rowCount() 메서드를 제공합니다. 그러나 다양한 드라이버에 대한 신뢰성은 보장되지 않습니다. PDO 문서에 따르면:

"대부분의 데이터베이스에서 PDOStatement::rowCount()는 SELECT 문의 영향을 받은 행 수를 반환하지 않습니다... 대신 PDO::query()를 사용하여 SELECT COUNT(*) 문... 그런 다음 PDOStatement::fetchColumn()을 사용하여 반환될 행 수를 검색합니다."

이러한 경우 다음을 사용할 수 있습니다. PDO::fetchAll() 함수를 사용하여 데이터를 배열로 검색한 다음 count()를 사용하여 행 수를 결정합니다.

$data = $pdo->fetchAll();
$number_of_rows = count($data);

또는 쿼리가 단순하고 변수를 활용하지 않는 경우 query() 함수를 직접 사용할 수 있습니다:

$nRows = $pdo->query('select count(*) from blah')->fetchColumn();
echo $nRows;

위 내용은 PHP에서 PDO를 사용하여 행 개수를 얻는 최적의 접근 방식은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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