>데이터 베이스 >MySQL 튜토리얼 >SQL Server 2008에서 특정 수의 상위 행을 효율적으로 삭제하는 방법은 무엇입니까?

SQL Server 2008에서 특정 수의 상위 행을 효율적으로 삭제하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-16 12:38:17514검색

How to Efficiently Delete a Specific Number of Top Rows in 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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