2012. 11. 5. 14:11

[Oracle] PL/SQL - 패키지 (Package)

패키지

 

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

 

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

 

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

 

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

 

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

 

- 패키지 구성 : 서브 프로그램 명세(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');

 

 

2010. 6. 29. 14:24

[Oracle] PL/SQL

PL/SQL 이란 ?
    -  PL/SQL 은 Oracle’s Procedural Language extension to SQL. 의 약자 입니다.
    -  SQL문장에서 변수정의, 조건처리(IF), 반복처리(LOOP, WHILE, FOR)등을 지원하며, 오라클 자체에      
        내장되어 있는 Procedure Language입니다
    -  DECLARE문을 이용하여 정의되며, 선언문의 사용은 선택 사항입니다.
    -  PL/SQL 문은 블록 구조로 되어 있고 PL/SQL 자신이 컴파일 엔진을 가지고 있습니다
    
PL/SQL의 장점 
    -  PL/SQL 문은 BLOCK 구조로 다수의 SQL 문을 한번에 ORACLE DB 로 보내서 처리하므로 수행속도를
        향상 시킬수 있습니다.
    -  PL/SQL 의 모든 요소는 하나 또는 두개이상의 블록으로 구성하여 모듈화가 가능하다.
    -  보다 강력한 프로그램을 작성하기 위해서 큰 블록안에 소블럭을 위치시킬 수 있습니다.
    -  Variable, Constant, Cursor, Exception을 정의하고, SQL문장과 Procedural 문장에서 사용합니다.
    -  단순, 복잡한 데이터형태의 변수를 선언합니다.
    -  테이블의 데이터 구조와 DataBase의 컬럼럼에 준하여 동적으로 변수를 선언 할 수 있습니다.
    -  Exception 처리 루틴을 이용하여 Oracle Server Error를 처리합니다.
    -  사용자 정의 에러를 선언하고 Exception 처리 루틴으로 처리 가능 합니다.


1. 프로시져
    -  특정 작업을 수행할수 있고, 이름이 있는 PL/SQL 블록으로서. 매개 변수를 받을수 있고, 반복적으로 
       사용할수 있습니다. 보통 연속 실행 또는 구현이 복잡한 트랜잭션을 수행하는 PL/SQL블록을 데이터
       베이스에 저장하기 위해 생성합니다. 
    
     * CREATE OR REPLACE 구문을 사용하여 생성합니다. 
     * IS 로 PL/SQL의 블록을 시작합니다. 
     * LOCAL 변수는 IS 와 BEGIN 사이에 선언합니다.     
    

2. 함수(Function)
    -  보통 값을 계산하고 결과값을 반환하기 위해서 함수를 많이 사용 합니다.
    -  대부분 구성이 프로시저와 유사 하지만 IN 파라미터만 사용 할 수 있습니다.
    -  반드시 반환될 값의 데이터 타입을 RETURN문에 선언해야 합니다.
    -  또한 PL/SQL블록 내에서 RETURN문을 통해서 반드시 값을 반환해야 합니다.

3. package
    -  패키지(package)는 오라클 데이터베이스에 저장되어 있는 서로 관련있는 PL/SQL 프로지져와 함수들의
        집합 입니다
    -  패키지는 선언부와 본문 두 부분으로 나누어 집니다.  

4. 트리거
    -  INSERT, UPDATE, DELETE문이 TABLE에 대해 행해질 때 묵시적으로 수행되는 PROCEDURE 입니다.
    -  Trigger는 TABLE과는 별도로 DATABASE에 저장됩니다.
    -  Trigger는 VIEW에 대해서가 아니라 TABLE에 관해서만 정의될 수 있습니다.