[ 패키지 ]
: 연관성이 있는 함수나 프로시저를 그룹으로 모아놓은 개념.
[ 패키지 구성 ]
: 선언부 + 몸체부
**참고로 패키지 선언부에 선언되지 않아도 패키지 몸체부에서
사용할 수 있다... BUT 권장사항이 아니다.
[ 구문 형식 ]
- 선언부 형식
create (or replace) package 패키지명
IS
패키지 내 전역 변수 선언;
procedure 프로시저1(매개변수1,...);
procedure 프로시저2(매개변수1,...);
function 함수1(매개변수1,..2)return 타입;
...
end;
- 몸체부 형식
create (or replace) package body 패키지명
IS
procedure 프로시저 이름
subprogram bodis : 실제 작동하게될 서브프로그램(프로시저, 함수)
end;
*패키지 실행 : 패키지는 여러 환경에서 호출되어 실행가능하다.
패키지에 대한 실행권한을 가진 사용자만 실행시킬 수 있다.
exec 패키지명.프로시저or함수명;
select 패키지명.함수명(매개변수) from ~~
*패키지 삭제 : 선언부와 몸체부를 모두 삭제할 수 있다. 또는 몸체만 삭제할 수도 있다.
drop package 패키지명; -- 둘 다 삭제할 경우
drop package body 패키지명; -- 몸체만 삭제할 경우
- 패키지 내에 전역 변수를 선언하고 해당 변수를 사용할 경우 초기화 작업이 필요한 경우가 있다.
이런 경우를 지원하기 위해
패키지.프로시저 or 함수를 수행할 때 마다 한번 무조건 실행하게 해 초기화 작업등을 할 수 있도록 지원하는 것이 있는데
이를 ONE_TIME_ONLY_PACKAGE 라고 한다.
방식은, 단순히 패키지 바디의 맨 아래 부분에 BEGIN을 기술하고 초기화 작업등을 해주면 된다.
'스터디 > DB(ORACLE)' 카테고리의 다른 글
ORACLE 트리거(trigger) (0) | 2017.09.21 |
---|---|
ORACLE 중간 연습... 프로시저를 활용한 데이터 조작 (0) | 2017.09.20 |
ORACLE 서브프로그램 함수(Function) (0) | 2017.09.19 |
ORACLE 서브프로그램의 이해와 프로시저 - (9) (0) | 2017.09.18 |
ORACLE 예외처리 개념, 종류, 사용법 - (8) (0) | 2017.09.18 |