>백엔드 개발 >C++ >.NET의 T-SQL 저장 프로시저에서 인쇄 출력을 어떻게 캡처할 수 있습니까?

.NET의 T-SQL 저장 프로시저에서 인쇄 출력을 어떻게 캡처할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-17 16:26:11978검색

How Can We Capture Print Output from a T-SQL Stored Procedure in .NET?

.NET 응용 프로그램의 T-SQL 저장 프로시저에서 인쇄 출력 검색

레거시 애플리케이션 마이그레이션에는 오류 보고 또는 정보 메시지용 PRINT 문을 사용하는 T-SQL 저장 프로시저 처리가 포함되는 경우가 많습니다. 이 문서에서는 .NET 환경PRINT 내에서 이

출력을 캡처하는 방법을 보여줍니다.

PRINT 출력 캡처: 실행 가능한 솔루션

.NET 애플리케이션 내의 T-SQL 저장 프로시저에서 PRINT 문의 출력을 검색할 수 있습니다. 이는 프로시저 논리에 포함된 디버깅 정보나 오류 메시지에 액세스하는 데 중요합니다.

C# 구현: 이벤트 처리

해결 방법은 데이터베이스 연결 개체의 InfoMessage 이벤트를 구독하는 것입니다. 다음은 C# 코드 예제입니다.

<code class="language-csharp">myConnection.InfoMessage += new SqlInfoMessageEventHandler(myConnection_InfoMessage);

void myConnection_InfoMessage(object sender, SqlInfoMessageEventArgs e)
{
    // Process the captured print message
    Console.WriteLine(e.Message); 
}</code>

코드 분석:

  • myConnection: 저장 프로시저를 실행하는 데 사용되는 데이터베이스 연결을 나타냅니다.
  • InfoMessage 이벤트: 이 이벤트는 데이터베이스 서버가 PRINT 출력
  • 을 포함하여 정보 메시지를 보낼 때마다 트리거됩니다.
  • e.Message: 이 속성은 PRINT 문의 내용을 담고 있습니다.

예시: 저장 프로시저 및 C# 코드

메시지를 인쇄하는 간단한 저장 프로시저를 생각해 보겠습니다.

<code class="language-sql">CREATE PROCEDURE usp_PrintMessage
AS
    PRINT 'This is a test message.';</code>

이 절차를 실행하고 PRINT 출력을 캡처하는 해당 C# 코드는 다음과 같습니다.

<code class="language-csharp">SqlCommand cmd = new SqlCommand("usp_PrintMessage", myConnection);
cmd.CommandType = CommandType.StoredProcedure;

cmd.InfoMessage += myConnection_InfoMessage; // Subscribe to the event

cmd.ExecuteNonQuery(); // Execute the stored procedure

// The print message will be displayed on the console.</code>

InfoMessage 이벤트를 구독하면 C# 애플리케이션이 저장 프로시저에서 생성된 PRINT 출력을 효과적으로 가로채서 처리하므로 강력한 오류 처리 및 정보 로깅이 가능해집니다.

위 내용은 .NET의 T-SQL 저장 프로시저에서 인쇄 출력을 어떻게 캡처할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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