메뉴 건너뛰기

조회 수 15036 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

PL/SQL(Procedure, Package)을 사용하다 보면 동적으로 쿼리(Query)를 생성하거나 텍스트(text) 쿼리를 입력 받아서 실행해야하는 경우가 있다다음 두가지 방법을 적절히 사용하면 좋은 결과를 얻을수 있다.

 

EXECUTE IMMEDIATE : Inset, Update, Delete 구문을 실행하거나 Select 구문을 실행 시 INTO를 사용하여 단일 값을 리턴 받을 때 사용

 

OPEN-FOR : Select 구문을 실행 시 Cursor를 리턴 받을 때 사용

 

주의 바인드 변수(:) 사용 시 쿼리 내부에서 변수명은 의미가 없고 변수 순서, 개수가 USING의 변수 순서, 개수와 일치해야 한다. 바인드 변수가 없다면 USING는 생략가능.

 

1. EXECUTE IMMEDIATE (INSERT, UPDATE, DELETE  등 구문 실행)

 

CREATE OR REPLACE PROCEDURE

PC_SET_HOLIDAY ( in_hldy_dte in date

, in_hldy_nm in varchar2

, in_use_yn in varchar2)

IS

v_query varchar(1000);

d_sysdate date;

BEGIN

BEGIN

-- 단일 값을 리턴받을때

EXECUTE IMMEDIATE 'SELECT SYSDATE FROM DUAL' INTO d_sysdate;

END;

 

v_query := v_query || 'INSERT INTO HOLIDAY';

v_query := v_query || ' VALUES(:1,:2,:3,:4)';

 

BEGIN

-- INSERT, UPDATE, DELETE 구문 실행

EXECUTE IMMEDIATE v_query

USING in_hldy_dte, in_hldy_nm, in_use_yn, d_sysdate;

END;

END;

 

 

2. OPEN-FOR (CURSOR를 리턴 받을 때)

 

CREATE OR REPLACE PROCEDURE

PC_GET_HOLIDAY ( in_fromdate in varchar2

, in_todate in varchar2

, out_cursor out SYS_REFCURSOR)

IS

v_query varchar(1000);

BEGIN

v_query := v_query || 'SELECT HLDY_DTE, HLDY_NM';

v_query := v_query || ' FROM HOLIDAY';

v_query := v_query || ' WHERE HLDY_DTE BETWEEN :in_fromdate';

v_query := v_query || ' AND :in_todate';

 

BEGIN

-- CURSOR를 리턴 받을때

OPEN out_cursor FOR v_query

USING in_fromdate, in_todate;

END;

END;

 

 

 

 

 


List of Articles
번호 제목 날짜 조회 수
101 linux oracle 서비스 시작 및 확인 ( 간단 ) 2016.09.11 12296
100 ROLLUP 합계, 소계 구하기 (GROUP BY) file 2016.12.08 11869
99 Oracle SQL Developer 도구 활용하기 - Part1 file 2016.12.08 11740
98 Oracle에서 세자리 콤마 찍기 file 2016.08.29 11720
97 Oracle DBMS_CRYPTO 사용하기 - 암복호화 하기 file 2016.12.08 11610
96 Oracle DB 에서 Toad 를 사용하여 Procedure 디버깅 하기 file 2016.08.30 11427
95 Oracle SQL Developer 도구 활용하기 - Part2 file 2016.12.08 11317
94 실수로 지운 데이터 복구 쿼리 (TIMESTAMP) 2016.12.08 11166
93 SQL 쿼리문 보기 좋게 정렬해주는 사이트 - Instant SQL Formatter file 2016.08.29 10991
92 오라클 인스턴스 클라이언트(oracle instant client) 2016.09.12 10980
91 CentOS 6.5 에 Oracle Database 11g Release 2 설치하기 file 2016.12.08 10855
90 [Oracle 12g] 설치 후 오라클 관리자 계정 접속하기 file 2016.12.08 10721
89 oracle log 보기 - alert, trace 2016.09.11 10650
88 [Oracle] Rownum을 이용한 페이징 처리 2016.12.08 10385
87 oracle 10g - log, trc 관리 정책 스크립트 2016.09.11 10088
86 Toad 사용시 캐릭터 인코더 UTF-8 로 변경하기 file 2016.08.30 10077
85 스키마 조회 쿼리 모음 2016.09.12 10036
84 rownum 사용 - 최근글 몇개만 가져오기 2016.12.08 9984
83 오라클 DB 백업과 복원 2016.12.08 9926
82 오라클 웹로직 12.1.3 설치 방법 file 2016.09.21 9902
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved