PL / SQL-절차

이 장에서는 PL / SQL의 프로 시저에 대해 설명합니다. ㅏsubprogram특정 작업을 수행하는 프로그램 단위 / 모듈입니다. 이러한 하위 프로그램은 결합되어 더 큰 프로그램을 형성합니다. 이를 기본적으로 '모듈 형 설계'라고합니다. 서브 프로그램은 다른 서브 프로그램이나calling program.

서브 프로그램을 만들 수 있습니다-

  • 스키마 수준에서
  • 패키지 내부
  • PL / SQL 블록 내부

스키마 수준에서 하위 프로그램은 standalone subprogram. CREATE PROCEDURE 또는 CREATE FUNCTION 문으로 생성됩니다. 데이터베이스에 저장되며 DROP PROCEDURE 또는 DROP FUNCTION 문으로 삭제할 수 있습니다.

패키지 내부에 생성 된 하위 프로그램은 packaged subprogram. 데이터베이스에 저장되며 DROP PACKAGE 문으로 패키지를 삭제 한 경우에만 삭제할 수 있습니다. 우리는 장에서 패키지에 대해 논의 할 것입니다'PL/SQL - Packages'.

PL / SQL 서브 프로그램은 매개 변수 세트로 호출 할 수있는 PL / SQL 블록입니다. PL / SQL은 두 종류의 하위 프로그램을 제공합니다.

  • Functions−이 서브 프로그램은 단일 값을 반환합니다. 주로 값을 계산하고 반환하는 데 사용됩니다.

  • Procedures−이 서브 프로그램은 값을 직접 반환하지 않습니다. 주로 작업을 수행하는 데 사용됩니다.

이 장에서는 PL/SQL procedure. 우리는 논의 할 것이다PL/SQL function 다음 장에서.

PL / SQL 하위 프로그램의 일부

각 PL / SQL 하위 프로그램에는 이름이 있으며 매개 변수 목록도있을 수 있습니다. 익명의 PL / SQL 블록과 마찬가지로 명명 된 블록은 다음 세 부분으로 구성됩니다.

S. 아니 부품 및 설명
1

Declarative Part

옵션 부품입니다. 그러나 서브 프로그램의 선언 부분은 DECLARE 키워드로 시작하지 않습니다. 여기에는 유형, 커서, 상수, 변수, 예외 및 중첩 된 하위 프로그램의 선언이 포함됩니다. 이러한 항목은 서브 프로그램에 국한되며 서브 프로그램이 실행을 완료하면 존재하지 않습니다.

2

Executable Part

이것은 필수 부분이며 지정된 작업을 수행하는 명령문을 포함합니다.

Exception-handling

이것은 다시 선택적인 부분입니다. 여기에는 런타임 오류를 처리하는 코드가 포함되어 있습니다.

프로 시저 생성

절차는 CREATE OR REPLACE PROCEDURE성명서. CREATE OR REPLACE PROCEDURE 문의 단순화 된 구문은 다음과 같습니다.

CREATE [OR REPLACE] PROCEDURE procedure_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
{IS | AS} 
BEGIN 
  < procedure_body > 
END procedure_name;

어디,

  • procedure-name프로 시저의 이름을 지정합니다.

  • [OR REPLACE] 옵션을 사용하면 기존 프로 시저를 수정할 수 있습니다.

  • 선택적 매개 변수 목록에는 매개 변수의 이름, 모드 및 유형이 포함됩니다. IN 외부에서 전달 될 값을 나타내고 OUT은 프로 시저 외부에서 값을 반환하는 데 사용되는 매개 변수를 나타냅니다.

  • procedure-body 는 실행 가능한 부분을 포함합니다.

  • 독립형 프로 시저를 작성하기 위해 IS 키워드 대신 AS 키워드가 사용됩니다.

다음 예제에서는 'Hello World!'문자열을 표시하는 간단한 프로 시저를 만듭니다. 실행되면 화면에.

CREATE OR REPLACE PROCEDURE greetings 
AS 
BEGIN 
   dbms_output.put_line('Hello World!'); 
END; 
/

위의 코드가 SQL 프롬프트를 사용하여 실행되면 다음 결과가 생성됩니다.

Procedure created.

독립형 절차 실행

독립형 프로시 저는 두 가지 방법으로 호출 할 수 있습니다.

  • 사용 EXECUTE 예어

  • PL / SQL 블록에서 프로 시저 이름 호출

위의 절차는 'greetings' EXECUTE 키워드를 사용하여 다음과 같이 호출 할 수 있습니다.

EXECUTE greetings;

위의 호출이 표시됩니다-

Hello World

PL/SQL procedure successfully completed.

이 절차는 다른 PL / SQL 블록에서 호출 할 수도 있습니다.

BEGIN 
   greetings; 
END; 
/

위의 호출이 표시됩니다-

Hello World  

PL/SQL procedure successfully completed.

독립형 프로 시저 삭제

독립형 프로시 저는 DROP PROCEDURE성명서. 프로 시저 삭제 구문은 다음과 같습니다.

DROP PROCEDURE procedure-name;

다음 명령문을 사용하여 인사말 절차를 삭제할 수 있습니다.

DROP PROCEDURE greetings;

PL / SQL 하위 프로그램의 매개 변수 모드

다음 표는 PL / SQL 하위 프로그램의 매개 변수 모드를 나열합니다.

S. 아니 매개 변수 모드 및 설명
1

IN

IN 매개 변수를 사용하면 값을 서브 프로그램에 전달할 수 있습니다. It is a read-only parameter. 서브 프로그램 내에서 IN 매개 변수는 상수처럼 작동합니다. 값을 지정할 수 없습니다. 상수, 리터럴, 초기화 된 변수 또는 표현식을 IN 매개 변수로 전달할 수 있습니다. 기본값으로 초기화 할 수도 있습니다. 그러나이 경우 서브 프로그램 호출에서 생략됩니다.It is the default mode of parameter passing. Parameters are passed by reference.

2

OUT

OUT 매개 변수는 호출 프로그램에 값을 리턴합니다. 서브 프로그램 내에서 OUT 매개 변수는 변수처럼 작동합니다. 값을 변경하고 할당 한 후 값을 참조 할 수 있습니다.The actual parameter must be variable and it is passed by value.

IN OUT

IN OUT매개 변수는 초기 값을 서브 프로그램에 전달하고 업데이트 된 값을 호출자에게 반환합니다. 값을 할당 할 수 있으며 값을 읽을 수 있습니다.

IN OUT 형식 매개 변수에 해당하는 실제 매개 변수는 상수 또는 표현식이 아닌 변수 여야합니다. 형식 매개 변수에는 값이 지정되어야합니다.Actual parameter is passed by value.

IN & OUT 모드 예 1

이 프로그램은 최소 두 값을 찾습니다. 여기서 프로시 저는 IN 모드를 사용하여 두 개의 숫자를 취하고 OUT 매개 변수를 사용하여 최소값을 반환합니다.

DECLARE 
   a number; 
   b number; 
   c number;
PROCEDURE findMin(x IN number, y IN number, z OUT number) IS 
BEGIN 
   IF x < y THEN 
      z:= x; 
   ELSE 
      z:= y; 
   END IF; 
END;   
BEGIN 
   a:= 23; 
   b:= 45; 
   findMin(a, b, c); 
   dbms_output.put_line(' Minimum of (23, 45) : ' || c); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Minimum of (23, 45) : 23  

PL/SQL procedure successfully completed.

IN & OUT 모드 예 2

이 절차는 전달 된 값의 제곱 값을 계산합니다. 이 예제는 동일한 매개 변수를 사용하여 값을 수락 한 다음 다른 결과를 반환하는 방법을 보여줍니다.

DECLARE 
   a number; 
PROCEDURE squareNum(x IN OUT number) IS 
BEGIN 
  x := x * x; 
END;  
BEGIN 
   a:= 23; 
   squareNum(a); 
   dbms_output.put_line(' Square of (23): ' || a); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Square of (23): 529 

PL/SQL procedure successfully completed.

매개 변수 전달 방법

실제 매개 변수는 세 가지 방법으로 전달할 수 있습니다.

  • 위치 표기법
  • 명명 된 표기법
  • 혼합 표기법

위치 표기법

위치 표기법에서는 프로 시저를 다음과 같이 호출 할 수 있습니다.

findMin(a, b, c, d);

위치 표기법에서 첫 번째 실제 매개 변수는 첫 번째 형식 매개 변수로 대체됩니다. 두 번째 실제 매개 변수는 두 번째 형식 매개 변수로 대체됩니다. 그래서,a 대체된다 x, b 대체된다 y, c 대체된다 zd 대체된다 m.

명명 된 표기법

명명 된 표기법에서 실제 매개 변수는 다음을 사용하여 형식 매개 변수와 연관됩니다. arrow symbol ( => ). 절차 호출은 다음과 같습니다.

findMin(x => a, y => b, z => c, m => d);

혼합 표기법

혼합 표기법에서는 프로 시저 호출에서 두 표기법을 혼합 할 수 있습니다. 그러나 위치 표기법은 명명 된 표기법 앞에 와야합니다.

다음 전화는 합법적입니다-

findMin(a, b, c, m => d);

그러나 이것은 합법적이지 않습니다.

findMin(x => a, b, c, d);