일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 자동형변환
- 제너릭
- 스프링
- 루프
- 인텔리제이
- 싱글톤
- https://start.spring.io
- 내장객체
- Java
- maven
- start.spring.io
- Short
- 메소드
- wrapper
- Scanner
- Jenkins
- 컬렉션
- 제네릭
- 빌드
- 박싱
- 클래스
- suvlet
- 싱글턴
- boxing
- bootstrap
- unboxing
- 무한
- 언박싱
- dependency
- 콜렉션
Archives
- Today
- Total
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;
/
'K-DigitalTraining 강의 > 2. Oracle + PLSQL' 카테고리의 다른 글
[6주차] 38. 마지막 핵심 종합 Test(지금까지 공부한 것을 점검) (0) | 2022.06.22 |
---|---|
[6주차] 37. PL/SQL언어, 예외처리 및 예외 강제로 발생시키기, 사용자 정의 예외 (0) | 2022.06.20 |
[6주차] 35. PL/SQL언어, 사용자 정의 프로시저(함수와 비슷하지만 반환값이 없음) (0) | 2022.06.17 |
[6주차] 34. PL/SQL언어, 재사용 가능한 이름있는 함수 작성방법 (0) | 2022.06.17 |
[6주차] 33. PL/SQL언어, 반복문의 종류(loop, for ~loop, while, 이중 반복문) (0) | 2022.06.17 |
Comments