>데이터 베이스 >MySQL 튜토리얼 >LINQ의 Skip() 및 Take()와 동일한 Direct SQL이 있습니까?

LINQ의 Skip() 및 Take()와 동일한 Direct SQL이 있습니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-15 15:27:20892검색

Is There a Direct SQL Equivalent to LINQ's Skip() and Take()?

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

이 쿼리는 다음 단계를 수행합니다.

  1. 'Sales.SalesOrderHeader' 정렬 테이블을 'OrderDate' 열을 기준으로 오름차순으로 정렬합니다.
  2. 첫 번째 항목 건너뛰기 'OFFSET' 절을 사용하여 1000개 행.
  3. 'FETCH NEXT' 절을 사용하여 다음 100개 행을 가져옵니다.

이 솔루션은 메모리에서 동일한 작업을 수행하는 것보다 훨씬 더 효율적입니다. , 모든 행을 선택할 필요가 없으므로 처음 1000개를 삭제하고 다음 100개를 수동으로 선택하면 됩니다.

위 내용은 LINQ의 Skip() 및 Take()와 동일한 Direct SQL이 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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