>데이터 베이스 >MySQL 튜토리얼 >LIMIT를 사용하지 않고 SQL Server에서 검색되는 레코드 수를 어떻게 제한할 수 있습니까?

LIMIT를 사용하지 않고 SQL Server에서 검색되는 레코드 수를 어떻게 제한할 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-18 18:34:11535검색

How Can I Limit the Number of Records Retrieved in SQL Server Without Using LIMIT?

SQL Server의 레코드 제한: LIMIT 초과

SQL Server는 다른 데이터베이스 시스템에서 일반적으로 사용되는 LIMIT 함수나 OFFSET 연산자를 지원하지 않습니다. 검색되는 레코드 수를 제한할 때 이는 문제가 될 수 있습니다.

그러나 SQL Server는 유사한 기능을 달성하기 위한 대체 방법을 제공합니다. 한 가지 방법은 WHERE 절과 함께 ROW_NUMBER() 함수를 사용하는 것입니다.

<code class="language-sql">SELECT * 
FROM ( 
  SELECT *, ROW_NUMBER() OVER (ORDER BY name) AS row 
  FROM sys.databases 
) a 
WHERE row > 5 AND row <= 10</code>

이 하위 쿼리는 각 행에 행 번호를 할당한 다음 지정된 범위 내의 행만 포함하도록 결과를 필터링합니다.

또 다른 방법은 TOP 절을 사용하는 것입니다.

<code class="language-sql">SELECT TOP 10 * FROM stuff</code>

TOP은 반환되는 행 수를 제한하지만 시작 위치에 대한 제어는 제공하지 않습니다.

SQL Server에는 왜 LIMIT가 없나요?

SQL Server에 LIMIT 함수가 없는 이유는 성능 문제 때문일 수 있습니다. LIMIT를 사용하면 특히 대규모 테이블에서 성능이 저하될 수 있습니다. SQL Server는 쿼리 실행 시간 최적화를 우선시합니다.

OFFSET 및 ROWS 사용

SQL Server 2012 이상의 경우 OFFSET 및 ROWS 키워드를 사용하여 결과 집합을 보다 세부적으로 제어할 수 있습니다.

<code class="language-sql">SELECT  *
FROM     sys.databases
ORDER BY name 
OFFSET  5 ROWS 
FETCH NEXT 5 ROWS ONLY</code>

이 쿼리는 처음 5개 행을 건너뛰고 다음 5개 행을 검색하여 LIMIT에 필적하는 제한 기능을 제공합니다.

위 내용은 LIMIT를 사용하지 않고 SQL Server에서 검색되는 레코드 수를 어떻게 제한할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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