집 >데이터 베이스 >MySQL 튜토리얼 >SQL Server 2008에서 특정 수의 상위 행을 효율적으로 삭제하는 방법은 무엇입니까?
Sql Server 2008의 효율적인 최상위 행 삭제
SQL Server 2008의 맨 위에서 특정 수의 행을 제거해야 하는 상황을 상상해 보세요. SQL Server의 테이블. 직관적인 접근 방식은 TOP 절과 쌍을 이루는 DELETE 문을 사용하는 것일 수 있지만 모든 행이 실수로 삭제되는 문제가 발생할 수 있습니다. 이 문제를 해결하려면 다음 지침을 고려하십시오.
실행하려고 시도한 코드로 인해 테이블에서 모든 행이 삭제되는 것으로 나타났습니다. 이는 코드가 DELETE 문과 TOP 절이 있는 SELECT 문이라는 두 개의 서로 다른 문으로 구성되어 있기 때문입니다. ORDER BY 절을 지정하지 않은 TOP 절은 삭제할 행을 효과적으로 식별할 수 없습니다.
행을 선택적으로 제거하려면 TOP 절 내에 순서 지정 기준을 설정해야 합니다. 또한 CTE(공통 테이블 표현식) 또는 유사한 테이블 표현식을 생성하는 것은 정의된 수의 최상위 행을 삭제하는 매우 효율적인 방법입니다.
다음 코드 조각은 보다 안정적인 접근 방식을 보여줍니다.
;WITH CTE AS ( SELECT TOP 1000 * FROM [mytab] ORDER BY a1 ) DELETE FROM CTE
이 코드에서 CTE는 특정 순서 기준에 따라 지정된 수의 행을 선택하여 원본 테이블에서 파생된 별도의 테이블을 설정합니다(이 경우 a1 열). 그 후 DELETE 문은 이 임시 테이블에서 행을 제거하여 상위 행만 삭제되도록 합니다.
위 내용은 SQL Server 2008에서 특정 수의 상위 행을 효율적으로 삭제하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!