>데이터 베이스 >MySQL 튜토리얼 >SQL_CALC_FOUND_ROWS는 어떻게 MySQL 페이지 매김 효율성을 향상시킬 수 있습니까?

SQL_CALC_FOUND_ROWS는 어떻게 MySQL 페이지 매김 효율성을 향상시킬 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-06 04:17:09308검색

How Can SQL_CALC_FOUND_ROWS Improve MySQL Pagination Efficiency?

SQL_CALC_FOUND_ROWS를 활용하여 MySQL 쿼리에서 페이지 매김 최적화

페이지 매김은 사용자가 기기에 부담을 주지 않고도 대규모 데이터 세트를 탐색할 수 있도록 하여 사용자 경험에서 중요한 역할을 합니다. OFFSET 및 LIMIT를 사용하여 MySQL 쿼리에서 페이지 매김을 구현할 때 필요한 페이지 수를 계산하기 위해 총 결과 수를 결정하는 것이 중요합니다.

그러나 여러 쿼리(하나는 페이지 매김용, 다른 하나는 계산용)를 실행하는 것은 계산적으로 비효율적입니다. MySQL은 SQL_CALC_FOUND_ROWS 수정자를 통해 더욱 최적화된 솔루션을 제공합니다.

SQL_CALC_FOUND_ROWS 구현

SQL_CALC_FOUND_ROWS를 활용하려면 원래 쿼리의 SELECT 문 앞에 추가하면 됩니다.

SELECT SQL_CALC_FOUND_ROWS * FROM table_name
WHERE category_id = ?
LIMIT ?, ?;

어디에서 ? 카테고리 ID, 오프셋, 제한에 대한 매개변수를 나타냅니다.

총 결과 개수 조회

수정된 쿼리를 실행한 후 FOUND_ROWS() 함수를 사용하여 조회합니다. LIMIT 없이 반환되었을 총 결과 수 절:

$total_results = $this->db->query("SELECT FOUND_ROWS()")->row()->total_results;

총 페이지 계산

이제 다음 공식을 사용하여 총 페이지 수를 계산할 수 있습니다.

$total_pages = ceil($total_results / $limit);

결론

사용하여 SQL_CALC_FOUND_ROWS를 사용하면 단일 쿼리로 총 결과 수를 얻을 수 있으므로 중복 실행이 필요하지 않습니다. 이 접근 방식은 리소스 활용도를 최적화하고 페이지 매김 메커니즘의 효율성을 향상시킵니다.

위 내용은 SQL_CALC_FOUND_ROWS는 어떻게 MySQL 페이지 매김 효율성을 향상시킬 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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