2021년 12월 25일 토요일

오라클 참조커서, RefCursor, 자바JDBC에서 오라클함수리턴값받기, SQL교육, SQL학원, 오라클교육, 오라클학원, 자바교육, 자바학원,JAVA학원

 

오라클 참조커서, RefCursor, 자바JDBC에서 오라클함수리턴값받기, SQL교육, SQL학원, 오라클교육, 오라클학원, 자바교육, 자바학원,JAVA학원


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


오라클 참조커서, RefCursor, 자바JDBC에서 오라클함수리턴값받기, SQL교육, SQL학원, 오라클교육, 오

오라클 참조커서, RefCursor, 자바JDBC에서 오라클함수리턴값받기, SQL교육, SQL학원, 오라클교육, 오라클학원, 자바교육, 자바학원오라클 PL/SQL참조커서(Ref Cursor)참조커서로 SELECT결과를 클라이언트로

ojc.asia

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

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

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

https://www.youtube.com/watch?v=8hc030THr8w&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=16 


오라클 PL/SQL



참조커서(Ref Cursor)

참조커서로 SELECT결과를 클라이언트로 리턴

자바JDBC에서 Ref Cursor로 리턴받기




참조커서(REF CURSOR)


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



Declare
   Type refcur is ref cursor;
   cursor c is select * from dual;
   myCur refCur;
begin
  --myCur는 ref cursor
if (to_char(sysdate,'DY') = '일') then
    open myCur for select * from emp;
elsif (to_char(sysdate,'DY') != '일') then
    open myCur for select * from dept;
end if;
open c;  -- 일반커서
end;
/

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



-- 커서를 리턴할 수 있는 함수를 만든다. 

CREATE OR REPLACE FUNCTION emptest(v_deptno in number) RETURN SYS_REFCURSOR    AS

       test_cursor SYS_REFCURSOR;

       sql_string Varchar2(500);

BEGIN

       sql_string := 'Select empno, ename, sal from Emp where deptno = :deptno' ;

       Open test_cursor FOR sql_string USING v_deptno;

       RETURN test_cursor;

       CLOSE test_Cursor;

  END;

  /


variable a refcursor ;

exec :a := emptest(20) ;

print a;



EMPNO ENAME             SAL

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

      7566 JONES            2975

      7788 SCOTT            3000

      7876 ADAMS            1100

      7902 FORD             3000


-- JAVA/JSP등에서 확인


                Class.forName(driver_name); //jdbc 드라이버연결

                conn =  DriverManager.getConnection(url,user,pwd); //Connection인수 입력

               

                String proc_call = "{? = call emptest(?)}";

             

                // 오라클 함수 또는 프로시저를 호출하기 위해 callable statement를 이용

                CallableStatement cstmt = conn.prepareCall(proc_call);

 

                // key here is to register the output parameter

                // of type cursor, execute, then cast it as a ResultSet.

                -- emptest 함수의 output 파라미터 타입을 CURSOR로 한다.

                -- 첫번째  ?가 출력파라미터, 두번째 파리미터는 입력파라미터

                cstmt.registerOutParameter(1, OracleTypes.CURSOR);

                cstmt.setInt(2, 10);  //10번 부서의 데이터 얻기 위해

                cstmt.executeQuery();


                rs = (ResultSet)cstmt.getObject(1);

                while(rs.next()) {

                        out.println(rs.getString("ename") + "<br>");

                        ……

                }



#참조커서, #오라클참조커서, #RefCursor, #오라클커서, #커서란, #SQL교육, #SQL학원, #오라클학원, #오라클교육, #자바교육, #자바학원, #오라클동영상, 참조커서, 오라클참조커서, RefCursor, 오라클커서, 커서란, SQL교육, SQL학원, 오라클학원, 오라클교육, 자바교육, 자바학원, 오라클동영상, 
 

PLSQL 커서,파라미터커서,Parameterized Cursor실습,PL/SQL커서,학원공부도 좋지만혼자해보세요~오라클교육,자바교육,SQL교육, JAVA학원, SQL학원

 











오라클 PLSQL 커서, 파라미터커서, Parameterized Cursor실습, PL/SQL커서, 학원공부도 좋지만 혼자해보세요~오라클교육, 자바교육, SQL교육



오라클 PL/SQL



Parameterized 커서



실습




Parameterized 커서


  • Parameter를 받을 수 있는 커서, 외부의 입력값을 이용하여 커서를 만들 때 사용한다.


[실습]

Parameterized 커서를 이용하여 급여의 하한값과 상한값을 입력받아 사원의 이름과 급여를 출력하는 프로시저를 작성하세요.


set serveroutput on;

create or replace procedure printEmp(p_low_sal in number, p_high_sal in number)
is
    CURSOR c_emp (low_sal NUMBER, high_sal NUMBER)
    IS  SELECT ename, sal FROM emp
        WHERE sal BETWEEN low_sal AND high_sal;
    v_ename emp.ename%type;
    v_sal   emp.sal%type;
BEGIN    
    OPEN c_emp(p_low_sal, p_high_sal);
    LOOP
        FETCH c_emp INTO v_ename, v_sal;
        EXIT WHEN c_emp%notfound;
        dbms_output.put_line(v_ename || ': ' ||v_sal);
    END LOOP;    
    CLOSE c_emp;
END;
/

exec printEmp(2500, 5000);

JONES: 2975
BLAKE: 2850
CLARK: 2500
SCOTT: 3000
KING: 5000
FORD: 3000



[실습]

Parameterized 커서를 이용하여 부서 테이블에서 모든 부서를 순회하면서 부서원들의 이름을 출력하는 프로시저를 작성하세요.(DEPT, EMP 테이블용 2개의 커서를 사용)

set serveroutput on

create or replace procedure printDeptEmp
is
 CURSOR c_dept IS SELECT * FROM dept;
 CURSOR c_emp(p_deptno emp.deptno%TYPE) IS
     SELECT ename, sal FROM emp WHERE deptno = p_deptno;
BEGIN
  FOR dept IN c_dept LOOP
    DBMS_OUTPUT.PUT_LINE('=========================');
    DBMS_OUTPUT.PUT_LINE(dept.deptno|| ' :: ' || dept.dname);
      FOR emp_record IN c_emp (dept.deptno) LOOP
       DBMS_OUTPUT.PUT_LINE(emp_record.ename || ' , ' || emp_record.sal);
     END LOOP;
 END LOOP;
END;
/

exec printDeptEmp;

=========================
10 :: ACCOUNTING
CLARK , 2500
MILLER , 1360
=========================
20 :: RESEARCH
JONES , 2975
SCOTT , 3000
ADAMS , 1100
FORD , 3000
=========================
30 :: SALES
ALLEN , 1600
WARD , 1250
MARTIN , 1250
BLAKE , 2850
TURNER , 1500
JAMES , 950
=========================
40 :: OPERATIONS




#오라클, #PLSQL, #PLSQL커서, #파라미터커서, #ParameterizedCursor, #오라클커서, #오라클교육, #자바교육, #SQL교육, #자바학원, #오라클학원, #SQL학원, 오라클, PLSQL, PLSQL커서, 파라미터커서, ParameterizedCursor, 오라클커서, 오라클교육, 자바교육, SQL교육, 자바학원, 오라클학원, SQL학원, 



PL/SQL 커서, Where Current Of, PLSQL Cursor, PK, ROWID, 오라클 PLSQL에서 커서다루기, 자바학원, 자바교육, 오라클학원, JAVA학원

 

PL/SQL 커서, Where Current Of, PLSQL Cursor, PK, ROWID, 오라클 PLSQL에서 커서다루기, 자바학원, 자바교육, 오라클학원, JAVA학원


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


PL/SQL 커서, Where Current Of, PLSQL Cursor, PK, ROWID, 오라클 PLSQL에서 커서다루기

PL/SQL 커서, Where Current Of, PLSQL Cursor, PK, ROWID, 오라클 PLSQL에서 커서다루기오라클 PL/SQLWhere Current Of Cursor강의 : 이종철WHERE CURRENT OF 커서ROWID, PK 컬럼을 이용하지 않고 현재 커서가 참조하는 행을 갱

ojc.asia

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

https://www.youtube.com/watch?v=8hc030THr8w&list=PLxU-iZCqT52CfP98Y4gCDKIm52tKvgy36&index=16 

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

오라클 PL/SQL


Where Current Of Cursor



강의 : 이종철



WHERE CURRENT OF 커서


  • ROWID, PK 컬럼을 이용하지 않고 현재 커서가 참조하는 행을 갱신하고 삭제하는 방법을 제공 합니다. 코드를 조금 줄여주는 이점외에 별 이점이 없으며, rowid를 이용하여 실무에서 많이 사용 합니다.
  • SELECT FOR UPDATE로 읽어 들인 행은 Exclusive Lock을 거니 조심해야 한다. 해당 테이블에 대해 다른 세션에서 변경하지 않은 편안한 시간에 작업을 하는 것이 좋습니다.


[실습]

사원 테이블에서 10번 부서 사원들을 읽어 급여(SAL) 2000 보다 크면 급여에 10을 더하고 작으면 20을 더하세요


-- PK를 이용한 방법

DECLARE

    CURSOR  c_emp  IS SELECT empno, ename, sal FROM emp WHERE DEPTNO = 10;

BEGIN

      FOR  emp_rec  IN  c_emp  LOOP

          DBMS_OUTPUT.PUT_LINE(emp_rec.ename || ',' || emp_rec.sal);

          IF  emp_rec.sal < 2000  THEN

                UPDATE emp  SET sal = sal + 20 

                where  empno = emp_rec.empno;

         ELSE

               UPDATE emp  SET sal = sal + 10

               where  empno = emp_rec.empno;

         END IF;

     END LOOP;

END;

/


CLARK,2450

MILLER,1300


select ename, sal from emp where deptno = 10;


CLARK 2460

MILLER 1320


rollback;


-- rowid를 이용한 방법

DECLARE

    CURSOR  c_emp  IS SELECT rowid, empno, ename, sal FROM emp WHERE DEPTNO = 10;

BEGIN

      FOR  emp_rec  IN  c_emp  LOOP

          DBMS_OUTPUT.PUT_LINE(emp_rec.ename || ',' || emp_rec.sal);

          IF  emp_rec.sal < 2000  THEN

                UPDATE emp  SET sal = sal + 20 

                where  rowid = emp_rec.rowid;

         ELSE

               UPDATE emp  SET sal = sal + 10

               where  rowid = emp_rec.rowid;

         END IF;

     END LOOP;

END;

/


-- WHERE CURRENT OF 커서를 이용한 방법

DECLARE

    CURSOR  c_emp  IS SELECT ename, sal FROM emp WHERE DEPTNO = 10 FOR UPDATE;

BEGIN

      FOR  emp_rec  IN  c_emp  LOOP

          DBMS_OUTPUT.PUT_LINE(emp_rec.ename || ',' || emp_rec.sal);

          IF  emp_rec.sal < 2000  THEN

                UPDATE emp  SET sal = sal + 20;

                WHERE CURRENT OF c_emp;

         ELSE

               UPDATE emp  SET sal = sal + 10

               WHERE CURRENT OF c_emp;

         END IF;

     END LOOP;

END;

/






#PL/SQL, #WhereCurrentOf,#PLSQL, #Cursor, #오라클커서, #오라클CURSOR, #오라클교육, #오라클학원, #오라클동영상, #SQL학원, #SQL교육, PL/SQL, WhereCurrentOf,PLSQL, Cursor, 오라클커서, 오라클CURSOR, 오라클교육, 오라클학원, 오라클동영상, 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...