본문 바로가기
IT/델파이

Delphi TStoredProcedure에서 CreateParameter를 이용한 파라미터 생성 및 전달 방법

by 불멸남생 2024. 7. 31.

델파이 프로그래밍 언어는 다양한 데이터베이스 작업을 수행할 수 있도록 여러 컴포넌트를 제공합니다. 그 중 TStoredProcedure 컴포넌트는 데이터베이스에서 저장된 프로시저를 호출하는 데 사용됩니다. 이 기사에서는 TStoredProcedure를 사용하여 CreateParameter를 이용해 파라미터를 생성하고 전달하는 방법에 대해 자세히 설명합니다.

TStoredProcedure 소개

TStoredProcedure는 델파이에서 데이터베이스 저장 프로시저를 호출할 수 있게 해주는 컴포넌트입니다. 저장 프로시저는 데이터베이스에서 자주 사용하는 SQL 쿼리를 미리 컴파일해 두고, 이를 호출하여 효율적으로 데이터베이스 작업을 수행할 수 있게 합니다.

반응형

TStoredProcedure의 기본 사용법

TStoredProcedure를 사용하려면 다음과 같은 단계를 따릅니다:

  1. 데이터베이스 연결 설정
  2. TStoredProcedure 컴포넌트 생성
  3. 저장 프로시저 호출
var
  StoredProc: TStoredProcedure;
begin
  StoredProc := TStoredProcedure.Create(nil);
  try
    StoredProc.DatabaseName := 'MyDatabase';
    StoredProc.StoredProcName := 'MyStoredProcedure';
    StoredProc.ExecProc;
  finally
    StoredProc.Free;
  end;
end;
반응형

파라미터 자동 생성

델파이에서는 TStoredProcedure를 사용할 때 Prepare 메서드를 호출하여 자동으로 파라미터를 생성할 수 있습니다. 이 경우 저장 프로시저에서 필요한 모든 파라미터가 자동으로 생성되므로 개발자는 따로 파라미터를 설정할 필요가 없습니다.

StoredProc.Prepare;

그러나, 저장 프로시저를 동적으로 생성하거나 파라미터를 수동으로 생성해야 할 경우에는 CreateParameter 메서드를 사용해야 합니다.

CreateParameter를 이용한 파라미터 생성

CreateParameter를 이용하여 파라미터를 수동으로 생성하려면 다음 단계를 따릅니다:

  1. TParam 객체 생성
  2. TParam 객체 설정
  3. TStoredProcedure에 TParam 추가
반응형
var
  Param: TParam;
begin
  Param := StoredProc.CreateParameter;
  Param.Name := 'MyParam';
  Param.DataType := ftInteger;
  Param.Value := 123;
  StoredProc.Params.Add(Param);
end;

파라미터 생성 순서

중요한 점은 파라미터를 생성할 때, 저장 프로시저를 만들 때 선언한 파라미터의 순서와 동일하게 CreateParameter를 호출해야 한다는 것입니다. 그렇지 않으면 정상적인 파라미터 전달이 이루어지지 않을 수 있습니다.

반응형
var
  Param1, Param2: TParam;
begin
  Param1 := StoredProc.CreateParameter;
  Param1.Name := 'FirstParam';
  Param1.DataType := ftString;
  Param1.Value := 'Value1';
  StoredProc.Params.Add(Param1);

  Param2 := StoredProc.CreateParameter;
  Param2.Name := 'SecondParam';
  Param2.DataType := ftInteger;
  Param2.Value := 123;
  StoredProc.Params.Add(Param2);
end;

이와 같이 파라미터를 올바른 순서로 생성하고 설정하면, 저장 프로시저가 예상대로 실행되고 원하는 결과를 얻을 수 있습니다.

반응형

파라미터 전달과 쿼리 결과 확인

파라미터를 생성하고 전달한 후에는 ExecProc 메서드를 호출하여 저장 프로시저를 실행합니다. 이때 반환되는 결과를 확인하여 올바른 값이 반환되었는지 검증할 수 있습니다.

StoredProc.ExecProc;
ShowMessage(StoredProc.ParamByName('OutputParam').AsString);

이와 같이 파라미터를 올바르게 설정하고 전달하면, 저장 프로시저가 예상대로 실행되고 원하는 결과를 얻을 수 있습니다.

파라미터 사용 예제

다음은 파라미터를 사용하여 간단한 저장 프로시저를 호출하는 예제입니다.

 

var
  StoredProc: TStoredProcedure;
begin
  StoredProc := TStoredProcedure.Create(nil);
  try
    StoredProc.DatabaseName := 'MyDatabase';
    StoredProc.StoredProcName := 'MyStoredProcedure';

    StoredProc.CreateParameter.Name := 'InputParam1';
    StoredProc.Params.ParamByName('InputParam1').Value := 'Value1';

    StoredProc.CreateParameter.Name := 'InputParam2';
    StoredProc.Params.ParamByName('InputParam2').Value := 123;

    StoredProc.ExecProc;
    ShowMessage(StoredProc.ParamByName('OutputParam').AsString);
  finally
    StoredProc.Free;
  end;
end;

이 예제에서는 두 개의 입력 파라미터와 하나의 출력 파라미터를 사용하여 저장 프로시저를 호출하고, 결과를 메시지 박스로 표시합니다.

반응형

결론

TStoredProcedure를 사용하여 저장 프로시저를 호출할 때, CreateParameter를 이용한 파라미터 생성은 매우 유용한 기능입니다. 이를 통해 파라미터를 동적으로 생성하고 필요한 값을 설정할 수 있습니다. 중요한 점은 파라미터 생성 순서를 정확히 지키는 것이며, 이를 통해 올바른 결과를 얻을 수 있습니다. 이 방법을 통해 데이터베이스 작업을 효율적으로 수행하고, 더욱 안정적인 애플리케이션을 개발할 수 있습니다.

반응형