PL/SQL (7) CURSOR, WHILE LOOP을 활용하여 데이터 확인하기
-- EMP_CURSOR%FOUND : 커서에서 데이터가 발견되면 TRUE
-- EMP_CURSOR%NOTFOUND : 커서에서 데이터가 발견되지 않으면 TRUE
SET SERVEROUTPUT ON;
ACCEPT P_DEPT_NO PROMPT '데이터가 필요한 부서를 입력하시오';
DECLARE
-- CURSOR 명 : EMP_CURSOR
-- EMP_CURSOR 에 조건에 맞는 TB_LS_EMP867 테이블에서 가져온 데이터들을 담아준다.
CURSOR EMP_CURSOR IS
SELECT EMP_NO, EMP_ID, EMP_NM, DEPT_NO, SAL
FROM TB_LS_EMP867
WHERE DEPT_NO = &P_DEPT_NO;
-- 변수를 선언한다.
V_EMP_NO NUMBER(8) := 0;
V_EMP_ID VARCHAR2(30);
V_EMP_NM VARCHAR2(20);
V_DEPT_NO NUMBER(4) := 0;
V_SAL NUMBER(10) := 0;
BEGIN
OPEN EMP_CURSOR;
FETCH EMP_CURSOR INTO V_EMP_NO, V_EMP_ID, V_EMP_NM, V_DEPT_NO, V_SAL;
WHILE EMP_CURSOR%FOUND LOOP
DBMS_OUTPUT.PUT_LINE(V_EMP_NM || '님의 레코드는 다음과 같습니다. : ' || V_DEPT_NO || ' | '
|| V_EMP_NM || ' | ' || V_EMP_ID || ' | ' || V_DEPT_NO || ' | ' || V_SAL );
FETCH EMP_CURSOR INTO V_EMP_NO, V_EMP_ID, V_EMP_NM, V_DEPT_NO, V_SAL;
-- next()와 비슷하게 생각해라.
END LOOP;
CLOSE EMP_CURSOR;
END;
/