Notice
Recent Posts
Recent Comments
관리 메뉴

Developer Gonie

[6주차] 36. PL/SQL언어, 한 줄 씩 가져와 모든 행의 레코드를 출력하는 방법(커서, 커서 + for~loop) 본문

K-DigitalTraining 강의/2. Oracle + PLSQL

[6주차] 36. PL/SQL언어, 한 줄 씩 가져와 모든 행의 레코드를 출력하는 방법(커서, 커서 + for~loop)

이대곤 2022. 6. 20. 10:50

커서를 이용해 한 줄 씩 가져와 모든 행의 레코드를 출력하는 방법

커서란?

쿼리문의 결과를 담을 수 있는 공간으로, 이 공간에 접근하기 위해서는 접근 시작전 open, 마무리 후 close를 해줘야 한다.
또한, 루프를 빠져나오기 위해 exit ... NOTFOUND를 사용해줘야 함.

커서 선언은 declare 부분에서 이뤄진다.

declare
	vno book.no%type;
	vtitle book.title%type;
	vpublisher book.publisher%type;
    
	cursor book_cursor is
		select no, title, publisher
		from book;
begin
	open book_cursor;
	loop
		fetch book_cursor into vno, vtitle, vpublisher; --fetch는 1줄씩 가져오는 것
		exit when book_cursor%NOTFOUND; --더이상 발견되지 않으면 빠져나가라
		dbms_output.put_line(vno || ',' || vtitle || ',' || vpublisher);
	end loop;
	close book_cursor;
end;
/

커서와 for~loop를 이용해 위와 동일한 결과를 만들어내는 방법(더욱 간결)

* for~loop문을 이용할 경우 시작전에 커서가 자동으로 열리고 끝나면 닫히기 때문에 이는 적어주지 않아도 됨.
* exit 부분 또한 가져올게 없으면 알아서 종료되기 때문에 적어주지 않아도 됨.

declare
	onerow book%rowtype; -- 한 줄의 모든 열의 값을 담을 수 있는 타입

	cursor book_cursor is
		select no, title, publisher
		from book;
begin
	--open book_cursor;
	for onerow in book_cursor loop
		--exit when book_cursor%NOTFOUND; --더이상 발견되지 않으면 빠져나가라
		dbms_output.put_line(onerow.no || ',' || onerow.title || ',' || onerow.publisher);
	end loop;
	--close book_cursor;
end;
/

 

Comments