[본문스크랩] PL/SQL (11) - 패키지 (Package)

오라클 | 2007. 12. 21. 15:30
Posted by 시반

 ###################################################################################################

#   source site : blog.naver.com/tangamjaelt

#   master : 강용운

#   email : tangamjaelt@korea.com

#   last release : 2007.06.09

###################################################################################################

 

패키지

- 서로 관련된 스키마 오브젝트들을 묶어 캡슐화 한 것.

- 컴파일되어 스키마 오브젝트로 데이터딕셔너리에 저장된다.

- 비슷한 작업을 수행하는 프로시저, 함수 등을 함께 묶어 사용한다.

- 패키지 자체는 호출해도 사용하지 못한다. 내부의 특정 서브 프로그램(프로시저,함수 등)을 호출해야 한다.

- "패키지.서브프로그램" 형식으로 호출한다.

- 패키지 구성 : 서브 프로그램 명세(Specification) + 서브 프로그램 본문(Body)

- 패키지 명세가 바뀌면 그 패키지를 참조하는 모든 스토어드 서브 프로그램을 다시 컴파일해야 한다.

- 패키지 본문은 바뀌어도 컴파일이 필요없다.

 

 

패키지를 사용하는 이유

- 보다 효율적인 모듈 단위로 구성하여 이해하기 쉽다.

- 패키지의 public 변수와 커서는 세션이 열려 있는 동안 지속되므로 세션에서 실행되는 모든 커서와 프로시저는 공유할 수 있다.

- 여러개의 오브젝트를 한번에 메모리로 올리기 때문에 성능 향상에 도움을 준다.

- 스토어드 프로시저와 함수를 갖고 있는 라이브러리를 사용해서 코드 재사용을 증진시켜 불필요한 코딩을 줄인다.

 

 

패키지 명세

- 패키지의 이름과 인수의 이름, 데이터형을 public으로 선언하는 부분.

- 패키지에 선언된 오브젝트는 패키지 어디에서나 접근 가능하다. (패키지에 대해 전역적)

- 응용 프로그램이 스토어드 서브 프로그램을 실행해야 하는 모든 정보는 패키지 명세에 들어 있다.

- 즉, 패키지 내에 어떤 오브젝트들이 있는지 미리 이름과 형식을 알리는 것임.

*******************************************************************************************************************

CREATE [OR REPLACE] PACKAGE 패키지이름

[AUTHID {CURRENT_USER | DEFINER} {IS | AS}

[패키지 본문 오브젝트 선언]

END 패키지이름;

*******************************************************************************************************************

- AUTHID : 패키지 실행시 호출할 권한의 유형.

       - CURRENT_USER : 현재 사용자(호출자)

       - DEFINER : 생성자

- 패키지 본문 오브젝트 선언 : 패키지에서 생성될 오브젝트의 목록을 적는 부분

 

 

패키지 본문

- 패키지 본문에는 명세에서 선언한 실제 오브젝트의 코드가 들어간다.

*******************************************************************************************************************

CREATE [OR REPLACE] PACKAGE BODY 패키지이름 {IS | AS}

   [패키지 본문 오브젝트 선언]

BEGIN

   프로그램문장

END 패키지이름;

*******************************************************************************************************************

 

패키지 서브 프로그램 호출

1. 사용자가 서브 프로그램에 대한 실행 권한을 가지고 있는지 확인한다.

2. Dictionary View에서 프로시저가 VALID 상태인지 확인한다. INVALID 라면 실행 전에 자동으로 재컴파일한다.

3. 패키지의 서브 프로그램을 실행한다.

4. 점(.)으로 패키지와 서브 프로그램을 구분하여 사용한다.

    - 패키지.형

    - 패키지.오브젝트

    - 패키지.서브프로그램

 

 

 

[예제1] id10 의 나이와 마일리지를 변경하는 프로시저를 포함하는 패키지 작성

 

1. 아래처럼 USERID 가 'id10' 인 홍길동이 있다.

 

 

 

2. 패키지 명세를 작성하고 실행한다. (패키지 이름 : change_pkg)

********************************************************************************************************************

CREATE OR REPLACE PACKAGE change_pkg AS
  PROCEDURE change_ages (i_id IN VARCHAR2);
  PROCEDURE change_mileage (i_id IN VARCHAR2);
END change_pkg;
/
********************************************************************************************************************

 

 

3. 패키지 몸체(Body)를 작성하고 실행시킨다. (change_ages, change_mileage)

********************************************************************************************************************

CREATE OR REPLACE PACKAGE BODY change_pkg AS

        i_id VARCHAR2(10);

 

PROCEDURE change_ages (i_id IN VARCHAR2) IS
BEGIN
        UPDATE member
        SET AGE=100
        WHERE userid = i_id;
END change_ages;

 

PROCEDURE change_mileage (i_id IN VARCHAR2) IS
BEGIN
        UPDATE member
        SET MILEAGE=777
        WHERE userid = i_id;
END change_mileage;

END change_pkg;
/
********************************************************************************************************************

 

 

4. 패키지의 프로시저를 실행시킨다.

SQL> exec change_pkg.change_ages('id10');

SQL> exec change_pkg.change_mileage('id10');

 

 

###################################################################################################

#   source site : blog.naver.com/tangamjaelt

#   master : 강용운

#   email : tangamjaelt@korea.com

#   last release : 2007.06.03

###################################################################################################

 

프로시저 (procedure) 와 패키지 (package)

- 프로그램 유지 보수와 실행을 보다 쉽게 하기 위해서 프로그램 코드를 논리적으로 구성한 것.

- 1개 패키지 내에 여러개의 프로시저가 존재한다.

 

스토어드 프로시저 (stored procedure)

- 데이터베이스 내에 컴파일되어 저장된 프로시저.

- 데이터베이스에 저장된 프로시저는 오브젝트로 관리된다.

 

프로시저를 사용하는 이유

- 특정 문제나 작업을 해결하기 위해서 사용한다.

- 특정 기능을 담당하는 모듈(module) 단위로 되어 있다.

- 재사용이 가능하다.

- 스토어드 프로시저를 통해서만 데이터를 액세스할 수 있어 보안이 향상된다.

- 프로시저는 공유된 메모리 자원을 이용한다.

 

프로시저와 함수

- 둘은 출력의 형식이 다르다.

- 프로시저 : 많은 양의 정보를 처리한다.

- 함수 : 하나의 값을 Return 한다.

 

프로시저 생성

- 프로시저를 생성할 때 오라클은 컴파일하는 동안 접근하는 오브젝트(Table,View 등)가 존재하는지 검사하고, 접근 권한이 있는지를 검사한다.

********************************************************************************************************************

CREATE OR REPLACE PROCEDURE 프로시저이름 (IN/OUT/INOUT)

AS

     PL/SQL 본문코드

END 프로시저이름

********************************************************************************************************************

- OR REPLACE : 프로시저가 이미 존재할 경우 덮어 쓴다. 항상 사용하는 것이 좋다.

- IN : 호출되는 프로시저에 값을 전달한다는 것을 지정

- OUT : 프로시저를 호출한 프로그램에게 값을 반환한다는 것을 지정

- INOUT : IN + OUT. 프로시저에 값을 전달하고 결과를 프로그램에게 반환한다는 것을 지정.

 

RETURN 문

- 프로시저가 끝나기 전에 마칠 경우에만 사용한다.

 

컴파일 / 재컴파일

- 스토어드 프로시저를 명시적으로 재컴파일 하려면 ALTER PROCEDURE 명령을 사용한다.

- ALTER PROCEDURE 는 패키지 내에 있는 프로시저가 아닌 독립된 프로시저에서만 사용 가능하다.

- 프로시저가 컴파일되면, 다음 실행시 컴파일 할 필요가 없어 부하를 줄일 수 있고, 컴파일 오류를 제거할 수 있다.

- 오라클은 부모 오브젝트가 명시적으로 다시 컴파일될 때 종속된 모든 오브젝트를 자동으로 재컴파일 한다. 따라서 부모 오브젝트를 컴파일 할 경우 관련된 모든 오브젝트가 모두 다시 컴파일이 일어나므로 시스템에 부하를 줄 수 있다.

 

프로시저 실행

- execute 명령으로 스토어드 프로시저를 실행할 수 있다.

 

[예제1]  사용자가 지정한 나이를 가진 사람의 나이를 100 으로 변경하는 스토어드 프로시저

********************************************************************************************************************

CREATE OR REPLACE PROCEDURE change_ages (i_age IN integer)
AS
BEGIN
        UPDATE member
        SET AGE=100
        WHERE age = i_age;
END change_ages;
/
********************************************************************************************************************

 

 

- 프로시저 실행

 

 

- 결과 확인 (62  -> 100 살로 변경)

 

 

 

파라미터

- 프로시저는 파라미터를 사용하여 정보를 전달한다.

- 프로시저를 호출할 때는 프로시저의 파라미터에 대해 값을 전달해야 한다.

- Actual Parameter : 프로시저에 전달된 파라미터 (실제 파라미터)

- Internal or Formal Parameter : 프로시저 내부에 선언된 파라미터 (내부 또는 형식 파라미터)

- Actual Parameter 의 데이터형과 Internal Parameter 의 데이터형이 같아야 한다.

 

 

스토어드 프로시저 확인

- 스토어드 프로시저에 관한 정보를 제공하는 데이터 딕셔너리 뷰

 

ALL_ERRORS : 현재 사용자가 액세스 가능한 모든 오브젝트에 대한 오류 목록

ALL_SOURCE : 현재 사용자가 액세스 가능한 모든 오브젝트의 텍스트 소스

 

USER_OBJECTS : 현재 사용자가 액세스 가능한 모든 오브젝토 목록

USER_ERRORS : 현재 사용자에게 속한 오브젝트의 오류 목록

USER_OBJECT_SIZE : 현재 사용자의 모든 PL/SQL 오브젝트

USER_SOURCE : 현재 사용자에게 속한 모든 오브젝트의 텍스트 소스

 

DBA_OBJECTS : 데이터베이스에 저장된 모든 오브젝트 목록

DBA_ERRORS : 데이터베이스에 저장된 모든 오브젝트에 대한 오류 목록

DBA_OBJECT_SIZE : 데이터베이스에 있는 모든 PL/SQL 오브젝트

DBA_SOURCE : 데이터베이스 전체에 대한 정보

 

- 어떤 오브젝트가 INVALID 상태인지 확인하고 다시 컴파일 할 필요가 있는지 확인할 수 있다.

- INVALID 인 함수나 프로시저는 잘못된 구문이 있을 수 있다.

 

SQL> select object_name, object_type, status from user_objects where status = 'INVALID';

 

 

 

프로시저 삭제

DROP PROCEDURE 프로시저이름;

 

프로시저 오버로딩

- 한 패키지에서 동일한 이름의 프로시저에 각각 다른 인수를 사용해서 호출할 수 있다.

- 서로 다른 데이터형을 갖고 있는 인수를 가지고 동일한 프로시저를 여러 번 실행해야할 경우 유용하다.

 

재귀 프로시저

- 자기 자신을 호출하는 프로시저

 
 

[본문스크랩] PL/SQL (6) - 패키지 사용의 예

오라클 | 2007. 12. 21. 15:28
Posted by 시반

###################################################################################################

#   source site : blog.naver.com/tangamjaelt

#   master : 강용운

#   email : tangamjaelt@korea.com

#   last release : 2007.05.18

###################################################################################################

 

회사에서 수많은 오라클 패키지를 볼 수 있다.

내가 짠 건 아니지만, 패키지가 이런 곳에 쓰이는구나라고 처음 알게되었다.

패키지... 언뜻 책만 본 학생들은 감이 오지 않겠지만 실제 필드에서 사용되는 패키지는 강력한 도구임에 틀림없다.

 

DB엔 회사에 관련된 모든 정보가 저장되어 있으며, 이를 관리하는게 DBMS 이다.

DB엔 임직원들의 인사정보가 모두 들어있을 것이며,

인사부에서 사용되는 인사프로그램엔 특정인의 이름을 입력하면 그 사람의 ID가 나온다고 생각해보자.

인사프로그램에서 '사용자ID 조회'라는 메뉴가 있어서 이를 사용하여 '강용운'이란 이름을 쳐 넣으면, 정보가 나올것이다.

 

1. 인사프로그램은 정보를 가져오기 위해 DB에 접속하여 q_account 라는 패키지의 get_userid 프로시저를 호출하게된다.

     패키지 내에는 get_userid 말고도 여러가지 프로시저가 존재하기 때문에 프로시저 이름을 반드시 지정 해주어야 한다.

    인자값으로는 사용자가 입력해준 값 '강용운'이 input 된다.

 

2. 프로시저는 '강용운'이란 값을 받아 DB에서 userid 를 select 하여 찾아낸다.

    결과를 인사프로그램에 Return 해준다.

   

3. 인사프로그램은 받은 결과를 예쁘게(?) 화면에 표시해준다.

 

 

중간에 체크 로직을 넣을 수도 있다.

만약, 이름이 없거나, 한글자만 들어왔다면, 프로시저에서 인자값이 잘못들어 왔음을 인사프로그램에 알리고,

이 코드를 받은 인사프로그램은 사용자에게 다시 확인하라는 메시지를 줄 수 있다.

 

IF v_name IS NULL or length(v_name) < 2 THEN

     error code;

ELSIF

     select userid, username

        from user_account

        where username = v_name;

END IF;

END;

 
블로그 이미지

시반

시반(詩伴)이란 함께 시를 짓는 벗이란 뜻을 가지고 있습니다. 함께 나눌수 있는 그런 공간이길 바라며...

카테고리

분류 전체보기 (233)
개발 이야기 (73)
WEB2.0 (57)
DB2 (24)
MySQL (6)
오라클 (26)
기타 (44)
취미 (0)
잡담 (2)