SQL Server 2008 테이블에서 상위 1000개 행 삭제
SQL Server 2008에서는 테이블에서 상위 1000개 레코드를 효율적으로 제거할 수 있습니다. CTE(공통 테이블 표현식)와 후속 삭제 문의 조합을 사용하여 테이블을 생성합니다. 작동 방식은 다음과 같습니다.
원래 문제가 있는 쿼리:
처음에 시도한 코드는 두 개의 별도 문으로 구성되어 있으므로 테이블의 모든 행을 삭제합니다. 셀렉트. select 문은 순서 기준을 지정하지 않으므로 모든 행이 삭제됩니다.
CTE를 사용하여 수정된 코드:
이 문제를 해결하기 위해 다음과 같은 CTE를 활용합니다. 'CTE'는 'a1' 열을 기준으로 오름차순으로 상위 1000개 행을 선택합니다. 그런 다음 후속 삭제 문은 CTE를 대상으로 하여 특정 레코드만 제거되도록 합니다.
;WITH CTE AS ( SELECT TOP 1000 * FROM [mytab] ORDER BY a1 ) DELETE FROM CTE
이 방법을 사용하면 나머지 레코드에 영향을 주지 않고 테이블에서 원하는 행 수를 효율적으로 삭제할 수 있습니다.
위 내용은 SQL Server 2008 테이블에서 상위 1000개 행을 효율적으로 삭제하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!