페이지 매김은 사용자가 기기에 부담을 주지 않고도 대규모 데이터 세트를 탐색할 수 있도록 하여 사용자 경험에서 중요한 역할을 합니다. 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!