2022년 1월 8일 토요일

오라클PLSQL DBMS_SQL 참조커서(REFCURSOR) 실습, 동적SQL,TO_REFCURSOR,오라클교육,SQL교육,JAVA교육,오라클학원,SQL학원,SQL동영상

 오라클PLSQL DBMS_SQL 참조커서(REFCURSOR) 실습, 동적SQL,TO_REFCURSOR,오라클교육,SQL교육,JAVA교육,오라클학원,SQL학원,SQL동영상


http://ojc.asia/bbs/board.php?bo_table=LecSQLnPlSql&wr_id=729 


PLSQL DBMS_SQL 참조커서(REFCURSOR) 실습, 동적SQL,TO_REFCURSOR,오라클교육,SQL교육,JAVA교육,오라클학원,SQL

PLSQL DBMS_SQL 참조커서(REFCURSOR) 실습, 동적SQL,TO_REFCURSOR,오라클교육,SQL교육,JAVA교육,오라클학원,SQL학원,SQL동영상오라클 PL/SQLDBMS_SQL일반커서를 참조커서로 변경리턴하기실습DBMS_SQL 패키지를 이용한

ojc.asia

https://www.youtube.com/watch?v=XJOkRPZYSYo&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=41 

https://www.youtube.com/watch?v=tO4rkJAC7FM&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=40 


https://www.youtube.com/watch?v=oR_UKxk_HO4&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=39 

https://www.youtube.com/watch?v=e9lZ0oZNZDo&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=38



https://www.youtube.com/watch?v=fYfTQruthLA&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=36 


DBMS_SQL 패키지를 이용한 참조커서(REF CURSOR)


  • 기본적으로 DBMS_SQL 패키지는 동적 SQL을 사용하여 DML(데이터 조작 언어) 또는 DDL(데이터 정의 언어) 문을 구문 분석, 실행, 데이터 조작할 수 있는 인터페이스를 제공한다.


  • DBMS_SQL 패키지의 PARSE 프로시저를 사용하여 SQL 구문을 파싱하며, DDL의 경우 별도의 EXECUTE 프로시저를 호출하지 않아도 된다.


  • ORACLE 11g이후 DBMS_SQL의 TO_REFCURSOR를 이용하여 일반 커서를 참조커서(REF CURSOR)로  변경할 수 있다.


  • 일반 커서는 정적이며 커서가 한번 SQL 영역을 가리키면 가리키는 곳을 변경 못한다. 하지만  참조커서(REF CURSOR)는 가능하다.


  • 일반 커서가 가리키는 데이터는 함수나 프로시저를 호출한 곳으로 리턴 할 수 없지만 참조커서(REF CURSOR)가 가리키는 데이터는 리턴하는 것이 가능하다.




[실습 : DBMS_SQL로 일반커서를 참조커서로 변환하고 리턴]

-- 이번에는 REF CURSOR를 리턴해 보자.

-- 아래처럼 함수의 리턴타입을 SYS_REFCURSOR로 하고 v_rc 변수의 타입도 SYS_REFCURSOR로 주면 된다. 

CREATE OR REPLACE FUNCTION emplist (p_deptno emp.deptno%TYPE)

        RETURN SYS_REFCURSOR

    IS

           v_sql     CLOB;

           v_cursor  PLS_INTEGER;

           v_rc      SYS_REFCURSOR;  --REF CURSOR형

           v_execute PLS_INTEGER;

       BEGIN

          v_cursor := DBMS_SQL.OPEN_CURSOR;

          v_sql :='SELECT * FROM emp WHERE deptno = :d';

 

         -- Dynamic SQL문 파싱

         DBMS_SQL.PARSE(v_cursor, v_sql, DBMS_SQL.NATIVE);

 

         -- 바인드변수 바인딩

         DBMS_SQL.BIND_VARIABLE(v_cursor, 'd', p_deptno);

 

         -- SQL문 실행

         v_execute := DBMS_SQL.EXECUTE(v_cursor);

 

         -- REF CURSOR로 변환

         v_rc := DBMS_SQL.TO_REFCURSOR(v_cursor);

 

         return v_rc;

      END;

     /


함수가 생성되었습니다.


set autoprint on

variable refcur refcursor

exec :refcur := emplist(20);


     EMPNO ENAME      JOB          MGR   HIREDATE     SAL      COMM     DEPTNO

     -----------------------------------------------------------------------------------------------------

      7782   CLARK      MANAGER    7839     81/06/09     3404.4               10

      7839   KING       PRESIDENT             81/11/17     6946.8               10

      7934   MILLER     CLERK        7782     82/01/23     2257.5               10



 

#PLSQL, #DBMS_SQL, #참조커서, #REFCURSOR, #동적SQL, #TO_REFCURSOR,#오라클교육,#SQL교육,#JAVA교육,#오라클학원,#SQL학원,#SQL동영상, PLSQL, DBMS_SQL, 참조커서, REFCURSOR, 동적SQL, TO_REFCURSOR,오라클교육,SQL교육,JAVA교육,오라클학원,SQL학원,SQL동영상,  

2022년 1월 7일 금요일

DBMS_SQL패키지,OPEN_CURSOR, PARSE, EXECUTE, 동적SQL, 커서, DDL실습, Dynamic SQL실습,오라클교육, SQL교육, 오라클학원, SQL학원

 

DBMS_SQL패키지,OPEN_CURSOR, PARSE, EXECUTE, 동적SQL, 커서, DDL실습, Dynamic SQL실습,오라클교육, SQL교육, 오라클학원, SQL학원


https://www.youtube.com/watch?v=tO4rkJAC7FM&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=40 

http://ojc.asia/bbs/board.php?bo_table=LecSQLnPlSql&wr_id=728 


DBMS_SQL패키지,OPEN_CURSOR, PARSE, EXECUTE, 동적SQL, 커서, DDL실습, Dynamic SQL실습,오라클교육, SQL교육, 오

DBMS_SQL패키지,OPEN_CURSOR, PARSE, EXECUTE, 동적SQL, 커서, DDL실습, Dynamic SQL실습,오라클교육, SQL교육, 오라클학원, SQL학원오라클 PL/SQLDBMS_SQL 패키지란?DDL, 동적SQL실습DBMS_SQLDBMS_SQL 패키지는 동적 SQL을 사

ojc.asia

https://www.youtube.com/watch?v=fYfTQruthLA&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=37 


오라클 PL/SQL


DBMS_SQL 패키지란?

DDL, 동적SQL


실습




 

DBMS_SQL


  • DBMS_SQL 패키지는 동적 SQL을 사용하여 DML(데이터 조작 언어) 또는 DDL(데이터 정의 언어) 문을 구문 분석할 수 있는 인터페이스를 제공한다.


  • DBMS_SQL 패키지의 PARSE 프로시저를 사용하여 SQL 구문을 파싱하며, DDL의 경우 별도의 EXECUTE 프로시저를 호출하지 않아도 된다.


  • EXECUTE 프로시저는 처리된 건수를 리턴하는데, INSERT, UPDATE 및 DELETE 문에 대해서만 유효하다. DDL을 포함한 다른 유형의 문의 경우 반환 값은 정의되지 않으므로 무시해야 한다.


 

[실습1 : DBMS_SQL 패키지를 이용하여 테이블 생성여부 확인 후 테이블 삭제 및 생성]


CREATE OR REPLACE PROCEDURE DBMS_SQL_TEST 

AS

    cursor_id INTEGER;

    rows_processed INTEGER;

    v_cnt NUMBER;

BEGIN

    cursor_id := DBMS_SQL.OPEN_CURSOR;

    

    SELECT COUNT(*) INTO v_cnt FROM user_tables WHERE table_name = 'TEST';

    IF v_cnt > 0 THEN

       DBMS_SQL.PARSE(cursor_id, 'drop table test', DBMS_SQL.NATIVE);

       rows_processed := DBMS_SQL.EXECUTE(cursor_id);

               -- v6 또는 0 : 버전6, v7 또는 2 : 버전7, NATIVE 또는 1 : 연결된 데이터베이스의 정상적인 동작을 지정

       DBMS_SQL.PARSE(cursor_id, 'create table test ( id number, name varchar2(20)) ', DBMS_SQL.NATIVE);

       rows_processed := DBMS_SQL.EXECUTE(cursor_id);

       

       DBMS_OUTPUT.PUT_LINE('삭제 후 생성');

    ELSE

       DBMS_SQL.PARSE(cursor_id, 'create table test ( id number, name varchar2(20)) ', DBMS_SQL.NATIVE);

       rows_processed := DBMS_SQL.EXECUTE(cursor_id);

       DBMS_OUTPUT.PUT_LINE('생성');

    END IF;   

    

EXCEPTION

WHEN OTHERS THEN

    DBMS_SQL.CLOSE_CURSOR(cursor_id);

    DBMS_OUTPUT.PUT_LINE(SQLERRM);

END;


set serveroutput on

exec dbms_sql_test;

select * from test;

drop table test; 



[실습2 : DBMS_SQL 패키지를 이용하여 동적SQL 커서 생성 후 FETCH]

-- 아래 예제는 EMP 테이블에서 입력한 부서코드의 사원을 출력하는 예제이다.

-- DBMS_SQL 패키지를 이용하여 커서를 생성하고 FETCH후 출력

 CREATE OR REPLACE PROCEDURE GETEMPS(P_DEPTNO IN NUMBER)

AS

   V_SQL           VARCHAR2(1000);

   V_CURSOR        INTEGER;

   V_AFFECTED_ROWS INTEGER;

   V_EMPNO         EMP.EMPNO%TYPE;

   V_ENAME         EMP.ENAME%TYPE;

BEGIN

     -- SQL문을 처리하려면 열린 커서가 있어야 하는데 OPEN_CURSOR함수를 사용, 커서ID를 리턴

     V_CURSOR := DBMS_SQL.OPEN_CURSOR;


     V_SQL := 'SELECT ename, sal FROM emp WHERE deptno = :d';


     -- Dynamic SQL문 파싱

     DBMS_SQL.PARSE(V_CURSOR, V_SQL, DBMS_SQL.NATIVE);


     -- 바인드변수 바인딩

     DBMS_SQL.BIND_VARIABLE(V_CURSOR, 'd', P_DEPTNO);


     -- CURSOR로부터 추출된 칼럼의 값을 받는 변수 지정

     -- 커서명, 상대위치, 받을변수명 ,길이 지정

     DBMS_SQL.DEFINE_COLUMN (V_CURSOR, 1, V_EMPNO);

     DBMS_SQL.DEFINE_COLUMN (V_CURSOR, 2, V_ENAME, 20);


     -- SQL문 실행

     V_AFFECTED_ROWS := DBMS_SQL.EXECUTE(V_CURSOR);

     DBMS_OUTPUT.PUT_LINE('V_AFFECTED_ROWS : ' || V_AFFECTED_ROWS);


     -- CURSOR에서 데이터 추출

    WHILE(DBMS_SQL.FETCH_ROWS(V_CURSOR) > 0)

    LOOP

        -- FETCH 결과를 변수에 저장

        DBMS_SQL.COLUMN_VALUE(V_CURSOR,1,V_EMPNO);

        DBMS_SQL.COLUMN_VALUE(V_CURSOR,2,V_ENAME);


        DBMS_OUTPUT.PUT_LINE('EMPNO :' || V_EMPNO || 'ENAME : '|| V_ENAME);

    END LOOP;


    DBMS_SQL.CLOSE_CURSOR(V_CURSOR);

EXCEPTION

   WHEN OTHERS THEN

       IF DBMS_SQL.IS_OPEN(V_CURSOR) THEN

         DBMS_SQL.CLOSE_CURSOR(V_CURSOR);

       END IF;

END;

/


SET SERVEROUTPUT ON;

EXEC GETEMPS(20);




#DBMS_SQL, #오라클패키지,#OPEN_CURSOR, #동적SQL, #오라클커서, #오라클DDL, #동적SQL, #SQL실습,#오라클교육, #SQL교육, #오라클학원, #SQL학원, DBMS_SQL, 오라클패키지,OPEN_CURSOR, 동적SQL, 오라클커서, 오라클DDL, 동적SQL, SQL실습,오라클교육, SQL교육, 오라클학원, SQL학원, 

오라클 PLSQL 함수,팩토리얼, Factorial,함수실습, DBMS_OUTPUT,PUT_LINE,GET_LINE,ENABLE, DISABLE, SPOOL출력을파일,JAVA학원, ORACLE학원, JAVA교육, ORACLE교육

 




오라클 PLSQL 함수,팩토리얼, Factorial,함수실습, DBMS_OUTPUT,PUT_LINE,GET_LINE,ENABLE, DISABLE, SPOOL출력을파일,JAVA학원, ORACLE학원, JAVA교육, ORACLE교육


https://www.youtube.com/watch?v=Qf5u2u9Gt2Q&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=33





실습 : PL/SQL Factorial 구하는 함수 작성

PL/SQL 내부 및 외부에서 실행

  • 셀 병합
  • 행 분할
  • 열 분할
  • 너비 맞춤
  • 삭제


DBMS_OUTPUT 패키지

이론 / 실습







DBMS_OUTPUT 패키지는 PL/SQL 블록(BEGIN ~ END)이나 프로시저, 함수 등 SUB PROGRAM 및 패키지, 트리거등에서 메시지를 출력할 수 있는 기능을 제공하는데 메시지를 버퍼에 저장하고 버퍼에서 읽어오기 위한 기능을 제공하는 오라클 패키지 입니다.


이 패키지의 PUT 프로시저 및 PUT_LINE 프로시저를 사용하면 다른 트리거, 프로시저 또는 패키지에서 읽을 수 있는 정보를 버퍼에 저장할 수 있고, 별도의 PL/SQL 프로시저 또는 익명 블록에서 GET_LINE 프로시저 및 GET_LINES 프로시저를 호출하여 버퍼링된 정보를 표시할 수 있습니다.


ENABLE 프로시저를 호출하여 버퍼를 할당 하며(기본 20000 바이트), PUT, PUT LINE으로 버퍼에 메시지를 넣습니다. 버퍼 메시지의 각 라인은 라인끝(CARRIAGE RETURN/LINE FEED) 값을 가지고 있으며 CHR(13) || CHR(10)을 DBMS_OUT으로 출력하면 동일한 효과를 얻습니다.


PUT, PUT LINE으로 버퍼에 저장된 메시지는 GET_LINE, GET_LINES 으로 읽어 들일수 있으며 DBMS_OUTPUT.DISABLE 프로시저로 할당된 버퍼를 제거 합니다.


GET_LINES으로 읽을 때 라인을 읽어 들일 변수의 타입으로 DBMS_OUT 패키지에는 CHARARR 타입이 정의되어 있는데 형식은 다음과 같습니다.

  • 셀 병합


SQL*Plus의 경우 SQL 문 또는 익명 PL/SQL 호출을 실행한 후 GET_LINES를 호출합니다.



DBMS_OUTPUT.DISABLE;
메시지 출력을 비활성화
DBMS_OUTPUT.ENABLE(
buffer_size IN INTEGER DEFAULT 20000
);
메시지 출력 활성화, NULL을 입력하면 버퍼 사이즈는 무한
DBMS_OUTPUT.GET_LINE (
line OUT VARCHAR2,
status OUT INTEGER
);
버퍼에서 한 라인을 검색
메시지를 성공적으로 읽어 온 경우에는 0을 반환하고 그렇지 못한 경우에는 1을 반환.


DBMS_OUTPUT.GET_LINES (
lines OUT CHARARR,
numlines IN OUT INTEGER
);
버퍼에서 라인의 배열을 검색
DBMS_OUTPUT.NEW_LINE;
현재라인을 종료 하고 새 라인을 삽입
(라인의 종료를 마킹)
DBMS_OUTPUT.PUT(
item IN VARCHAR2
);
문자열을 출력 후 다음라인을 이동하지않고 대기
DBMS_OUTPUT.PUT_LINE(
item IN VARCHAR2
);
최대 32767 바이트로
버퍼에서 새롭게 문자열을 가진 한 라인을 삽입, 문자열을 출력 후 다음라인 이동


DBMS_OUTPUT.ENABLE(buffer_size IN INTEGER DEFAULT 20000); ⇒ 메시지 출력 활성화, NULL을 입력하면 buffer size는 무한


set serveroutput on

spool c:\logs\dbms.txt


BEGIN

-- 버퍼를 활성화, 기본버퍼 사이즈는 20000 바이트

dbms_output.enable;


dbms_output.put('굿 데이2!!');

dbms_output.put_line('안녕하세요~');

dbms_output.new_line();

dbms_output.put_line('즐거운 하루 되세요~');

--dbms_output.put('굿 데이!!');


dbms_output.put('굿 데이2!!');

dbms_output.put(CHR(13) || CHR(10));

dbms_output.put_line('안녕하세요2~');

--dbms_output.put('굿 데이2!!');

END;


create or replace procedure DBMS_TEST

is

begin

dbms_output.enable;

DBMS_OUTPUT.PUT_LINE('test1');

DBMS_OUTPUT.PUT_LINE('test2');

DBMS_OUTPUT.PUT_LINE('test3');

end;


declare

lines dbms_output.chararr;

num_lines number := 3;

begin

DBMS_TEST;


-- 아래 GET_LINE이하를 주석으로 막고 실행하면 프로시저에서 출력한 형태로 출력

dbms_output.get_lines(lines, num_lines);


FOR i IN 1..num_lines LOOP

dbms_output.put_line(i || '->' || lines(i));

END LOOP;

end;


declare

message VARCHAR(1024);

status INTEGER;

begin

DBMS_TEST;


DBMS_OUTPUT.GET_LINE(message, status);

DBMS_OUTPUT.PUT_LINE(message);

DBMS_OUTPUT.PUT_LINE(status);

end;


https://www.youtube.com/watch?v=UNWJDGNM-GY&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=35





#오라클, #DBMS_OUTPUT이란, #DBMS_OUTPUT, #PUT_LINE, #GET_LINE, #오라클프로시저, #오라클교육, #SQL교육, #자바교육, #오라클학원, #자바학원, #SQL학원, #오라클동영상, 오라클, DBMS_OUTPUT이란, DBMS_OUTPUT, PUT_LINE, GET_LINE, 오라클프로시저, 오라클교육, SQL교육, 자바교육, 오라클학원, 자바학원, SQL학원, 오라클동영상

#오라클, #PLSQL, #팩토리얼, #Factorial, #오라클함수, #함수실행, #바인드변수, #호스트변수, #오라클교육, #SQL교육, #오라클학원, #SQL학원, #자바교육, #자바학원, 오라클, PLSQL, 팩토리얼, Factorial, 오라클함수, 함수실행, 바인드변수, 호스트변수, 오라클교육, SQL교육, 오라클학원, SQL학원, 자바교육, 자바학원



(C#교육동영상)C# ADO.NET 실습 ODP.NET/ODAC 설치 오라클 함수 호출 실습, C#학원, WPF학원, 닷넷학원, 자바학원

  (C#교육동영상)C# ADO.NET 실습  ODP.NET/ODAC 설치  오라클 함수 호출 실습, C#학원, WPF학원, 닷넷학원, 자바학원 https://www.youtube.com/watch?v=qIPU85yAlzc&list=PLxU-i...