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 중국어 웹사이트의 기타 관련 기사를 참조하세요!