PL / SQL-함수

이 장에서는 PL / SQL의 함수에 대해 설명합니다. 함수는 값을 반환한다는 점을 제외하면 프로 시저와 동일합니다. 따라서 이전 장에서 설명한 모든 내용은 함수에도 적용됩니다.

함수 생성

독립형 기능은 CREATE FUNCTION성명서. 에 대한 단순화 된 구문CREATE OR REPLACE PROCEDURE 진술은 다음과 같습니다-

CREATE [OR REPLACE] FUNCTION function_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
RETURN return_datatype 
{IS | AS} 
BEGIN 
   < function_body > 
END [function_name];

어디,

  • function-name함수의 이름을 지정합니다.

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

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

  • 함수에는 return 성명서.

  • 반환 절은 데이터 당신이 함수에서 반환하려고하는 유형을 지정합니다.

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

  • 독립형 함수를 만들기 위해 IS 키워드 대신 AS 키워드가 사용됩니다.

다음 예제는 독립 실행 형 함수를 만들고 호출하는 방법을 보여줍니다. 이 함수는 customers 테이블의 총 CUSTOMERS 수를 반환합니다.

PL / SQL 변수 장 에서 생성 한 CUSTOMERS 테이블을 사용합니다.

Select * from customers; 
 
+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+
CREATE OR REPLACE FUNCTION totalCustomers 
RETURN number IS 
   total number(2) := 0; 
BEGIN 
   SELECT count(*) into total 
   FROM customers; 
    
   RETURN total; 
END; 
/

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

Function created.

함수 호출

함수를 만드는 동안 함수가 수행해야하는 작업에 대한 정의를 제공합니다. 함수를 사용하려면 정의 된 작업을 수행하기 위해 해당 함수를 호출해야합니다. 프로그램이 함수를 호출하면 프로그램 제어가 호출 된 함수로 전송됩니다.

호출 된 함수는 정의 된 작업을 수행하고 return 문이 실행되거나 last end statement 도달하면 프로그램 제어를 주 프로그램으로 되돌립니다.

함수를 호출하려면 함수 이름과 함께 필수 매개 변수를 전달하기 만하면됩니다. 함수가 값을 반환하면 반환 된 값을 저장할 수 있습니다. 다음 프로그램은 함수를 호출합니다.totalCustomers 익명 블록에서-

DECLARE 
   c number(2); 
BEGIN 
   c := totalCustomers(); 
   dbms_output.put_line('Total no. of Customers: ' || c); 
END; 
/

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

Total no. of Customers: 6  

PL/SQL procedure successfully completed.

다음 예제는 최대 두 개의 값을 계산하고 반환하는 단순 PL / SQL 함수의 선언, 정의 및 호출을 보여줍니다.

DECLARE 
   a number; 
   b number; 
   c number; 
FUNCTION findMax(x IN number, y IN number)  
RETURN number 
IS 
    z number; 
BEGIN 
   IF x > y THEN 
      z:= x; 
   ELSE 
      Z:= y; 
   END IF;  
   RETURN z; 
END; 
BEGIN 
   a:= 23; 
   b:= 45;  
   c := findMax(a, b); 
   dbms_output.put_line(' Maximum of (23,45): ' || c); 
END; 
/

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

Maximum of (23,45): 45   

PL/SQL procedure successfully completed.

PL / SQL 재귀 함수

우리는 프로그램이나 하위 프로그램이 다른 하위 프로그램을 호출 할 수 있음을 보았습니다. 서브 프로그램이 자신을 호출 할 때이를 재귀 호출이라고하며 프로세스는recursion.

개념을 설명하기 위해 숫자의 계승을 계산해 보겠습니다. n의 계승은 다음과 같이 정의됩니다.

n! = n*(n-1)! 
   = n*(n-1)*(n-2)! 
      ... 
   = n*(n-1)*(n-2)*(n-3)... 1

다음 프로그램은 자신을 재귀 적으로 호출하여 주어진 숫자의 계승을 계산합니다.

DECLARE 
   num number; 
   factorial number;  
   
FUNCTION fact(x number) 
RETURN number  
IS 
   f number; 
BEGIN 
   IF x=0 THEN 
      f := 1; 
   ELSE 
      f := x * fact(x-1); 
   END IF; 
RETURN f; 
END;  

BEGIN 
   num:= 6; 
   factorial := fact(num); 
   dbms_output.put_line(' Factorial '|| num || ' is ' || factorial); 
END; 
/

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

Factorial 6 is 720 
  
PL/SQL procedure successfully completed.