일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 클래스
- 언박싱
- boxing
- 싱글톤
- 무한
- suvlet
- 박싱
- Short
- Scanner
- 루프
- dependency
- 내장객체
- 메소드
- 싱글턴
- wrapper
- 콜렉션
- maven
- 제너릭
- bootstrap
- 제네릭
- 자동형변환
- 스프링
- 컬렉션
- unboxing
- https://start.spring.io
- start.spring.io
- Java
- Jenkins
- 빌드
- 인텔리제이
Archives
- Today
- Total
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;
'K-DigitalTraining 강의 > 2. Oracle + PLSQL' 카테고리의 다른 글
[6주차] 36. PL/SQL언어, 한 줄 씩 가져와 모든 행의 레코드를 출력하는 방법(커서, 커서 + for~loop) (0) | 2022.06.20 |
---|---|
[6주차] 35. PL/SQL언어, 사용자 정의 프로시저(함수와 비슷하지만 반환값이 없음) (0) | 2022.06.17 |
[6주차] 33. PL/SQL언어, 반복문의 종류(loop, for ~loop, while, 이중 반복문) (0) | 2022.06.17 |
[6주차] 32. PL/SQL언어, 변수의 타입을 간편하게 지정하는 방법, 1줄의 레코드를 한 번에 다 담을 수 있는 타입(%type, %rowtype) (0) | 2022.06.17 |
[6주차] 31. PL/SQL언어, case문 작성하는 방법 (0) | 2022.06.17 |
Comments