영향을 받은 테이블에 대해 실행된 SQL을 캡처하기 위한 트리거 생성
문제:
To 특정 테이블에 대한 알 수 없는 업데이트 문제를 해결하려면 변경을 초래한 실행된 SQL을 식별해야 합니다. 불행하게도 애플리케이션의 비즈니스 로직은 주로 데이터베이스에 상주하므로 이러한 업데이트의 소스를 확인하기가 어렵습니다.
목표:
다음 테이블에 트리거를 생성합니다. 문제에 영향을 미치는 SQL 문을 기록하여 범인 SQL을 식별할 수 있습니다.
SQL Server Extended를 사용한 접근 방식 이벤트:
1. 테스트용 데이터베이스 설정:
문제가 있는 시나리오를 시뮬레이션하는 데 필요한 테이블과 트리거가 포함된 간단한 데이터베이스를 만듭니다.
2. 확장 이벤트 세션 생성:
SQL Server 확장 이벤트를 사용하여 테이블에 대해 실행된 SQL 문을 캡처합니다. 여기에는 업데이트를 시뮬레이션하는 데 사용되는 트리거를 필터링하는 이벤트 세션을 생성하는 작업이 포함됩니다.
3. Proc1 프로시저 트리거:
Proc1을 실행하면 일련의 프로시저 호출이 트리거되어 결국 테이블에 대한 알 수 없는 업데이트가 발생합니다.
4. 확장 이벤트 세션 중지:
절차가 실행된 후 확장 이벤트 세션을 중지합니다.
5. 이벤트 데이터 분석:
fn_xe_file_target_read_file 함수를 사용하여 확장 이벤트 세션에서 캡처한 데이터를 읽고 호출 스택을 분석하여 실행된 SQL 문을 식별합니다.
의 장점 확장 이벤트 접근 방식:
추가 이점:
캡처된 확장 이벤트 데이터를 사용하여 쿼리 실행 계획 및 실행 통계를 분석하여 성능 문제를 해결할 수도 있습니다.
위 내용은 SQL Server 확장 이벤트는 특정 테이블에 영향을 미치는 SQL 문을 어떻게 식별할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!