[C# PL/SQL] 4.오라클 프로시저에서 예외 처리 및 C#에서의 에러 핸들링, 프로시저 내에서 예외를 처리하고 C#에서 이를 효과적으로 핸들링하는 방법을 설명

데이터베이스와 애플리케이션 간의 상호작용을 관리하기 위해 Oracle PL/SQL과 C# 언어는 각각 특정한 방식으로 예외 처리 및 에러 핸들링 체계를 갖추고 있습니다. 이 글에서는 오라클 프로시저 내에서의 예외 처리 방법과 C# 애플리케이션에서 이를 효과적으로 핸들링하는 방법에 대해 깊이 있게 다뤄보겠습니다. 이를 통해 오라클 데이터베이스와 C# 간의 상호작용에서 발생할 수 있는 다양한 오류 상황을 다루고, 안정적이며 효율적인 시스템을 구축하는 방법을 배우게 될 것입니다.

1. 오라클 PL/SQL의 예외 처리 소개

오라클의 PL/SQL(Procedural Language/Structured Query Language)에서는 다양한 상황에서 발생할 수 있는 에러를 관리하기 위해 강력한 예외 처리 메커니즘을 제공합니다. 예외(Exception)는 특정 조건에서 프로시저의 정상적인 흐름을 중단하게 만드는 이벤트를 의미합니다. 예외 처리는 기본적으로 다음의 두 가지 단계로 이루어집니다:

  1. 예외 발생: PL/SQL 블록에서 (예: SELECT, INSERT, UPDATE 등을 수행할 때) 특정한 오류가 발생했을 때, 오라클은 자동으로 예외를 발생시킵니다.
  2. 예외 처리: 발생한 예외를 캐치하고 적절한 처리를 수행하기 위한 예외 처리 블록을 작성합니다.

2. PL/SQL 예외 처리 구문

오라클 PL/SQL에서 예외 처리는 EXCEPTION 블록을 통해 수행됩니다. 기본적인 구문은 다음과 같습니다:

BEGIN
    -- PL/SQL 작업 수행
EXCEPTION
    WHEN <예외명> THEN
        -- 예외 처리 코드
    WHEN OTHERS THEN
        -- 다른 예외 처리 코드
END;

예외를 정의할 때, WHEN OTHERS를 사용하여 모든 예외를 처리할 수 있습니다. 이 블록 내에서 SQLCODESQLERRM을 사용하여 오류의 코드와 메시지를 출력할 수 있습니다.

예제: 오라클 프로시저의 예외 처리

CREATE OR REPLACE PROCEDURE example_procedure IS
    v_number NUMBER;
BEGIN
    SELECT 1 / 0 INTO v_number FROM dual; -- 의도적으로 제로 나누기 오류 발생
EXCEPTION
    WHEN ZERO_DIVIDE THEN
        DBMS_OUTPUT.PUT_LINE('Zero Division Error 발생!');
    WHEN OTHERS THEN
        DBMS_OUTPUT.PUT_LINE('다른 오류 발생: ' || SQLERRM);
END example_procedure;

위의 예제에서는 의도적으로 제로 나누기를 시도하여 ZERO_DIVIDE 예외를 발생시키고 이를 처리하여 메시지를 출력합니다.

3. C#에서의 예외 처리 기법

C#에서도 예외 처리 메커니즘을 통해 오류를 관리합니다. C#의 예외 처리는 try, catch, finally 블록을 통해 수행됩니다. 기본적으로 다음의 구문을 사용합니다:

try
{
    // 코드 실행
}
catch (예외타입 e)
{
    // 예외 처리 코드
}
finally
{
    // 항상 실행되는 코드
}

C# 예외 처리 예제

try
{
    int result = 10 / 0; // 의도적으로 제로 나누기 오류 발생
}
catch (DivideByZeroException e)
{
    Console.WriteLine("Zero Division Exception 발생: " + e.Message);
}
catch (Exception e)
{
    Console.WriteLine("기타 오류 발생: " + e.Message);
}

4. 오라클 프로시저와 C# 간의 예외 처리 연계

오라클의 PL/SQL 프로시저에서 발생하는 예외는 C# 애플리케이션에서도 적절하게 처리할 수 있어야 합니다. 이를 위해 C#에서 오라클 프로시저를 호출하고 예외를 처리하는 방법을 이해해야 합니다. 다음과 같은 과정을 거칩니다:

  1. 프로시저를 호출하고 결과를 확인합니다.
  2. 예외가 발생할 경우, C#은 해당 예외를 캐치하여 처리합니다.

오라클 프로시저 호출 예제

using Oracle.ManagedDataAccess.Client;

string connStr = "User Id=;Password=;Data Source=;";

try
{
    using (OracleConnection conn = new OracleConnection(connStr))
    {
        conn.Open();
        using (OracleCommand cmd = new OracleCommand("example_procedure", conn))
        {
            cmd.CommandType = CommandType.StoredProcedure;
            cmd.ExecuteNonQuery();
        }
    }
}
catch (OracleException e)
{
    Console.WriteLine("오라클 예외 발생: " + e.Message);
}
catch (Exception e)
{
    Console.WriteLine("기타 예외 발생: " + e.Message);
}

5. 오류 로그 기록 및 알림

예외 처리할 때 발생한 오류를 단순히 출력하는 것 외에도, 오류 로그를 기록하거나 특정 방식으로 알림을 주는 것이 좋은 실천입니다. Oracle PL/SQL에서 로그를 기록하기 위해 DBMS_OUTPUT을 사용하거나 사용자 정의 로그 테이블에 데이터를 삽입하는 방법이 있습니다.

예제: 오라클 로그 테이블에 오류 기록

CREATE TABLE error_log (
    log_id NUMBER PRIMARY KEY,
    log_message VARCHAR2(4000),
    log_time TIMESTAMP
);

CREATE OR REPLACE PROCEDURE log_error(p_message VARCHAR2) IS
BEGIN
    INSERT INTO error_log (log_id, log_message, log_time) VALUES (error_seq.NEXTVAL, p_message, SYSTIMESTAMP);
    COMMIT;
END log_error;

C#에서의 오류 로그 기록 포맷

try
{
    // DB 작업
}
catch (OracleException e)
{
    LogToDatabase("오라클 예외: " + e.Message);
}
catch (Exception e)
{
    LogToDatabase("기타 예외: " + e.Message);
}

void LogToDatabase(string message)
{
    using (OracleConnection conn = new OracleConnection(connStr))
    {
        using (OracleCommand cmd = new OracleCommand("log_error", conn))
        {
            cmd.CommandType = CommandType.StoredProcedure;
            cmd.Parameters.Add(new OracleParameter("p_message", message));
            cmd.ExecuteNonQuery();
        }
    }
}

6. 결론

오라클 프로시저에서의 예외 처리와 C#에서의 에러 핸들링은 데이터베이스와 애플리케이션 간의 상호작용을 보다 안전하고 신뢰성 있게 만들어 줍니다. 예외 처리 로직을 적절하게 구현함으로써, 발생 가능한 오류 상황에 대한 대처를 미리 준비할 수 있으며, 사용자 경험을 향상시키고 시스템의 안정성을 높일 수 있습니다. PL/SQL과 C#의 예외 처리 기법을 효과적으로 연계하여, 개발자는 보다 효과적으로 오류를 관리하고 해결할 수 있습니다.