SQL Server의 비동기 프로시저 실행
SQL Server 2008 R2의 컨텍스트에서 일반적인 쿼리에는 두 개의 문을 순차적으로 실행하는 작업이 포함됩니다.
EXECUTE sp_executesql N'PRINT ''1st '' + convert(varchar, getdate(), 126) WAITFOR DELAY ''000:00:10''' EXECUTE sp_executesql N'PRINT ''2nd '' + convert(varchar, getdate(), 126)'
그러나 두 번째 문은 첫 번째 문까지 실행되지 않은 상태로 유지됩니다. 완료합니다. 이러한 순차적 실행은 특히 첫 번째 문이 상당히 지연될 때 문제가 될 수 있습니다.
EXEC 문을 병렬로 실행할 수 있습니까?
이것이 가능합니까?라는 질문이 생깁니다. 성능을 최적화하기 위해 이러한 명령문을 병렬로 실행하려면? SQL Server에서는 비동기 프로시저 실행을 허용하지만 이 접근 방식은 이 경우 가장 적합한 솔루션이 아닐 수 있습니다.
비동기 프로시저 실행
비동기 프로시저 실행을 사용하면 저장 프로시저를 통해 다음을 수행할 수 있습니다. 별도의 SQL Server 세션에서 실행됩니다. 이렇게 분리하면 두 번째 문을 차단하지 않고 첫 번째 문이 계속 실행될 수 있습니다. 그러나 비동기 프로시저 실행은 주로 독립적이고 서로 종속되지 않는 요청을 위해 설계되었습니다.
데이터 액세스 및 병렬성
다음을 인식하는 것이 중요합니다. T-SQL은 주로 데이터 액세스 언어로 작동합니다. 트랜잭션, 잠금, 커밋/롤백 작업을 처리할 때 진정한 병렬성을 달성하는 것은 어렵습니다. 병렬 T-SQL은 일반적으로 각 요청이 독립적이고 작업 간 상관 관계가 없는 요청 대기열과 관련된 시나리오에서 사용됩니다.
대체 접근 방식
제공된 예제에서 목표는 레코드를 획득하고 잠근 다음 잠겨 있는 동안 다른 명령문을 실행하는 것이므로 병렬화가 최적의 솔루션이 아닐 수 있습니다. 대신 테이블 잠금 메커니즘과 스레드 관리 기술을 사용하여 동시 액세스 및 데이터 조작을 관리하는 것이 좋습니다.
위 내용은 SQL Server EXEC 문을 병렬로 실행할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!