> 데이터 베이스 > MySQL 튜토리얼 > SQL Server 2008에서 대량 삭제를 위한 표준 DELETE 문보다 더 빠른 대안이 있습니까?

SQL Server 2008에서 대량 삭제를 위한 표준 DELETE 문보다 더 빠른 대안이 있습니까?

Susan Sarandon
풀어 주다: 2025-01-03 10:29:43
원래의
792명이 탐색했습니다.

Is There a Faster Alternative to Standard DELETE Statements for Bulk Deletion in SQL Server 2008?

SQL Server 2008의 효율적인 대량 삭제

데이터베이스 관리에서는 효율적인 데이터 삭제에 대한 필요성이 자주 발생합니다. SQL Server는 표준 DELETE 문을 제공하지만 대규모 데이터 세트의 경우 시간이 많이 걸릴 수 있습니다. 이 질문은 SQL Server가 대량 DELETE 작업을 위해 대량 복사(bcp)에 대한 대안을 제공하는지 여부를 탐색합니다.

TRUNCATE를 사용할 수 없고 대신 WHERE를 사용하세요

제시된 쿼리 SQL Server에 대량 삭제를 위한 솔루션이 있는지 묻습니다. 문제는 삭제가 WHERE 절로 제한되어야 하므로 TRUNCATE가 적합하지 않은 옵션이 된다는 것입니다.

DELETE에 해당하는 대량 복사가 없습니다

안타깝게도 대량 복사가 없습니다. SQL Server의 DELETE 작업에 해당하는 복사본입니다. WHERE 절이 있는 DELETE 문은 표준 SQL 쿼리로 실행되어야 합니다.

확장성을 위한 일괄 DELETE

대규모 데이터세트의 경우 일괄 DELETE 작업을 고려하세요. 여기에는 아래와 같이 DELETE 문을 더 작은 배치로 나누는 작업이 포함됩니다.

SELECT 'Starting' --sets @@ROWCOUNT
WHILE @@ROWCOUNT <> 0
    DELETE TOP (xxx) MyTable WHERE ...
로그인 후 복사

높은 비율 삭제를 위한 대체 방법

대부분의 행을 삭제할 때, 다른 방법이 더 효율적일 수 있습니다.

SELECT col1, col2, ... INTO #Holdingtable
           FROM MyTable WHERE ..opposite condition..
TRUNCATE TABLE MyTable
INSERT MyTable (col1, col2, ...)
           SELECT col1, col2, ... FROM #Holdingtable
로그인 후 복사

위 내용은 SQL Server 2008에서 대량 삭제를 위한 표준 DELETE 문보다 더 빠른 대안이 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿