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

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

Susan Sarandon
Susan Sarandon원래의
2025-01-03 10:29:43777검색

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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