SQL Server 행 오프셋 : 페이지 매김 문제 해결
Pagination의 주요 측면 인 데이터의 서브 세트를 효율적으로 검색하려면 결과를 상쇄 할 수있는 기능이 필요합니다. 다른 많은 데이터베이스 시스템과 달리 SQL Server는 기본적으로 오프셋 절을 지원하지 않습니다.
문제 : 기본 오프셋 부족
일반적인 시나리오를 고려하십시오 : 테이블에서 행 51에서 75 행을 검색하십시오. 다른 데이터베이스에 사용되는 간단한 접근 방식 :
SELECT * FROM MyTable OFFSET 50 LIMIT 25
는 SQL Server에서 사용할 수 없습니다. 이를 위해서는 모든 선행 행을 처리하지 않고 특정 오프셋에서 시작하는 데이터를 검색하는 대체 방법을 찾아야합니다.
SQL Server 용 솔루션 (2005 이상) :
SQL Server 2005 이상 버전은 파생 된 테이블과 row_number ()
함수를 활용할 수 있습니다 :
SELECT col1, col2
FROM (
SELECT col1, col2, ROW_NUMBER() OVER (ORDER BY ID) AS RowNum
FROM MyTable
) AS MyDerivedTable
WHERE MyDerivedTable.RowNum BETWEEN @startRow AND @endRow;
이것은 각 레코드에 고유 한 행 번호를 할당하여
절을 통해 특정 범위를 선택할 수있게하여 오프셋 기능을 효과적으로 모방합니다.
SQL Server 2000 용 솔루션 :
SQL Server 2000에서 행 오프셋을 처리하는 것이 더 복잡합니다. 자세한 자습서 및 방법은 외부 리소스를 참조하십시오. 여기에는 종종 페이지 매김을 달성하기 위해 임시 테이블을 만들고 관리하는 것이 포함됩니다.
성능 최적화 :
최적의 성능 :
대신 *
를 선택하고 필요한 열만 나열합니다. id
쿼리 속도가 크게 향상됩니다. 이러한 기술을 사용함으로써 개발자는 데이터베이스 버전에 관계없이 SQL Server에서 Pagination 및 Offset 기능을 효과적으로 구현할 수 있습니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3