>백엔드 개발 >PHP 튜토리얼 >오프셋 및 제한을 사용하여 MySQL 쿼리의 총 결과를 효율적으로 계산하려면 어떻게 해야 합니까?

오프셋 및 제한을 사용하여 MySQL 쿼리의 총 결과를 효율적으로 계산하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-23 13:21:01850검색

How Can I Efficiently Calculate Total Results in MySQL Queries with Offset and Limit?

MySQL 쿼리에서 오프셋 및 제한을 사용하여 총 결과를 결정하는 방법

Codeigniter 또는 유사한 PHP/MySQL 프레임워크를 사용하는 페이지 매김 시나리오에서는 다음과 같습니다. 총 페이지 수를 계산하려면 테이블의 총 결과 수를 결정하는 것이 중요합니다. 기능 제한 없이 두 번째 쿼리를 실행하는 표준 방법은 계산적으로 비효율적으로 보이지만, 이 프로세스를 최적화하는 대체 솔루션이 있습니다.

SQL_CALC_FOUND_ROWS 활용

MySQL은 특별한 기능을 제공합니다. SQL_CALC_FOUND_ROWS로 알려진 함수입니다. Limit 및 Offset 절이 있는 쿼리 앞에 이 문을 포함하면 데이터베이스는 제한 없이 반환되는 총 행 수가 특수 내부 변수에 저장되도록 보장합니다. 이를 통해 추가 쿼리 없이 총 개수를 효율적으로 검색할 수 있습니다.

예를 들어 다음 쿼리에는 SQL_CALC_FOUND_ROWS가 포함되어 있습니다.

SELECT * FROM my_table WHERE category_id = ? ORDER BY id LIMIT 10 OFFSET 20

총 개수를 검색하려면 다음을 실행하면 됩니다. 다음 쿼리:

SELECT FOUND_ROWS()

오프셋 또는 제한 매개변수에 관계없이 where 절을 충족하는 테이블의 총 행 수를 반환합니다. 이 값을 제한 값으로 나누면 페이지 매김에 필요한 총 페이지 수를 얻을 수 있습니다.

SQL_CALC_FOUND_ROWS를 사용하면 여러 번의 데이터베이스 호출이 필요 없고 전체 페이지에 대한 정확한 계산이 보장되므로 페이지 매김이 더욱 효율적이 됩니다. 페이지 수.

위 내용은 오프셋 및 제한을 사용하여 MySQL 쿼리의 총 결과를 효율적으로 계산하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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