Notice
Recent Posts
Recent Comments
관리 메뉴

Developer Gonie

[6주차] 34. PL/SQL언어, 재사용 가능한 이름있는 함수 작성방법 본문

K-DigitalTraining 강의/2. Oracle + PLSQL

[6주차] 34. PL/SQL언어, 재사용 가능한 이름있는 함수 작성방법

이대곤 2022. 6. 17. 14:30

* 만드려는 함수이름이 존재하는 테이블의 이름과 같으면 오류가 뜨는데,

  이럴 땐 테이블을 삭제해주던지 함수의 이름을 다르게 지정해 주어야 한다.

* 반환타입에 varchar2타입을 사용할 경우 사이즈는 지정하지 않고 'varchar2' 까지만 써줘야 한다.

1. 파라미터를 받지않는 함수 정의 및 호출방법

--test 라는 함수가 있으면 만들고 만들어놓은게 있다면 내가 만드는대로 변경해라
create or replace function test  -- 'test' 부분은 함수의 이름, 함수를 만들지만 test 라는 이름을 가진 테이블이 존재하면 에러남에 주의
return number as     -- return 타입이 number 라는 것, 이 부분은 declare를 대신해서 변수를 선언하는 부분이기도 함
	x number;
	y number;
begin
	x := 100;
	y := 200;
	return x+y;     -- 함수의 반환값
end;
/

함수가 생성되었습니다.

--위에서 만든 함수를 호출하는 방법, select 문을 이용하여 호출할 수 있음, 여기서는 괄호가 있어도 없어도 됨
select test() from dual;     -- 함수를 호출한 자리에 반환값이 대치됨
select test from dual;     -- 함수를 호출한 자리에 반환값이 대치됨

    TEST()
----------
       300
--테이블 레코드의 개수를 출력하는 함수

create or replace function test2
return number as 
	cnt number;
begin
	select count(*)
	into cnt
	from book;	

	return cnt;     -- 함수의 반환값
end;
/


select test2() from dual;

2. 파라미터가 있는 함수 정의 및 호출방법

create or replace function test3(a number, b number)
return number as 
	
begin
	return a+b; 
end;
/


select test3(10,20) from dual;

쿼리문으로 나오는 결과에 만든 함수를 적용하는 방법

create or replace function tax(vsalary members.salary%type) -- 이런 방식으로도 타입을 지정해줄 수 있음
return number as 
	
begin
	if vsalary >= 1000 then
		return vsalary * 0.2;
	elsif vsalary >= 500 then
		return vsalary * 0.1; 
	else
		return vsalary * 0.05;
	end if;
end;
/

select tax(1000) from dual;

 TAX(1000)
----------
       200

select id, name, salary, tax(salary) from members;

        ID NAME                     SALARY TAX(SALARY)
---------- -------------------- ---------- -----------
         1 제시카                      100           5
         2 티파니                      700          70
         3 수영                        300          15
         4 효연                        800          80
         5 효연                        200          10
         6 제시카                      500          50
         9 써니                        600          60
         7 유리                        500          50
         8 윤아                        300          15
        10 수영                    1000000      200000
-- 부서번호 대신 해당하는 부서명을 대치하여 보여줌
create or replace function match_dept(vdeptno company.deptno%type) 
return varchar2 as 
	
begin
	if vdeptno = 10 then
		return '개발부';
	elsif vdeptno = 20 then
		return '홍보부'; 
	elsif vdeptno = 30 then
		return '인사부'; 
	end if;
end;
/

select sabun, name, match_dept(deptno) from company;

만든 함수를 삭제하는 방법

drop function test;
Comments