SQL의 건너뛰기 및 가져오기: LINQ와 동등한
LINQ의 .Skip() 및 .Take() 메서드는 편리한 작업 방법을 제공합니다. 메모리에 데이터의 하위 집합이 있습니다. 그러나 기본 데이터 원본이 대규모 SQL 데이터베이스인 상황에서는 이러한 작업을 메모리보다는 SQL에서 직접 수행하는 것이 더 나은 경우가 많습니다. 이렇게 하면 대량의 데이터를 메모리로 전송하는 오버헤드가 방지됩니다.
이러한 시나리오 중 하나는 데이터베이스 테이블에서 특정 행 범위를 선택해야 하는 경우입니다. LINQ는 이 목적을 위해 .Skip() 및 .Take() 메서드를 제공하지만 직접 SQL에 해당하는 메서드가 있습니까?
SQL Server 2012 이상
SQL Server 2012 이상에서는 행 오프셋 및 제한을 위한 새로운 구문을 도입했습니다.
OFFSET (@Skip) ROWS FETCH NEXT (@Take) ROWS ONLY
To 특정 테이블에서 1000-1100행을 선택하려면 다음 쿼리를 사용합니다.
SELECT * FROM Sales.SalesOrderHeader ORDER BY OrderDate OFFSET 1000 ROWS FETCH NEXT 100 ROWS ONLY
이 쿼리는 다음 단계를 수행합니다.
이 솔루션은 메모리에서 동일한 작업을 수행하는 것보다 훨씬 더 효율적입니다. , 모든 행을 선택할 필요가 없으므로 처음 1000개를 삭제하고 다음 100개를 수동으로 선택하면 됩니다.
위 내용은 LINQ의 Skip() 및 Take()와 동일한 Direct SQL이 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!